aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoseph Hunkeler <jhunkeler@gmail.com>2026-04-06 15:54:13 -0400
committerJoseph Hunkeler <jhunkeler@gmail.com>2026-04-08 10:22:37 -0400
commit69e91b9f95b536983a95b15d224c82c9340dfaff (patch)
treec9c811e9841fbd7e8742405c5da4c9648c843b3b
parent0c1db22116e83826e1d5141b9ead29213d754911 (diff)
downloadstasis-69e91b9f95b536983a95b15d224c82c9340dfaff.tar.gz
Only free when allocated
-rw-r--r--src/lib/delivery/delivery.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/src/lib/delivery/delivery.c b/src/lib/delivery/delivery.c
index 4409e69..bba91fd 100644
--- a/src/lib/delivery/delivery.c
+++ b/src/lib/delivery/delivery.c
@@ -153,7 +153,7 @@ struct Delivery *delivery_duplicate(const struct Delivery *ctx) {
result->deploy.jfrog_auth.url = strdup_maybe(ctx->deploy.jfrog_auth.url);
result->deploy.jfrog_auth.user = strdup_maybe(ctx->deploy.jfrog_auth.user);
- for (size_t i = 0; i < result->tests->num_used; i++) {
+ for (size_t i = 0; result->tests && i < result->tests->num_used; i++) {
result->tests->test[i]->disable = ctx->tests->test[i]->disable;
result->tests->test[i]->parallel = ctx->tests->test[i]->parallel;
result->tests->test[i]->build_recipe = strdup_maybe(ctx->tests->test[i]->build_recipe);
@@ -230,7 +230,7 @@ void delivery_free(struct Delivery *ctx) {
guard_strlist_free(&ctx->conda.pip_packages_purge);
guard_strlist_free(&ctx->conda.wheels_packages);
- for (size_t i = 0; i < ctx->tests->num_used; i++) {
+ for (size_t i = 0; ctx->tests && i < ctx->tests->num_used; i++) {
guard_free(ctx->tests->test[i]->name);
guard_free(ctx->tests->test[i]->version);
guard_free(ctx->tests->test[i]->repository);
@@ -245,8 +245,10 @@ void delivery_free(struct Delivery *ctx) {
guard_free(ctx->tests->test[i]->runtime);
guard_free(ctx->tests->test[i]);
}
- guard_free(ctx->tests->test);
- guard_free(ctx->tests);
+ if (ctx->tests) {
+ guard_free(ctx->tests->test);
+ guard_free(ctx->tests);
+ }
guard_free(ctx->rules.release_fmt);
guard_free(ctx->rules.build_name_fmt);