diff options
| author | Joseph Hunkeler <jhunkeler@users.noreply.github.com> | 2024-10-04 16:12:26 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-10-04 16:12:26 -0400 | 
| commit | 70f76b377e2d35fa097b65a82fc7cac4f5f172d4 (patch) | |
| tree | 7ff5169c28b1c14d91ab00452806a087d1562690 /src | |
| parent | 6e72330a3cc8d571b14f2234ed8fc2778b5e9b86 (diff) | |
| parent | bf1ecd2deb3c2d777efe93c0da6212bdbcc2240e (diff) | |
| download | stasis-70f76b377e2d35fa097b65a82fc7cac4f5f172d4.tar.gz | |
Merge pull request #51 from jhunkeler/wheel-funcs-clean-up
Clean up get_wheel_info
Diffstat (limited to 'src')
| -rw-r--r-- | src/delivery_install.c | 25 | ||||
| -rw-r--r-- | src/wheel.c | 54 | 
2 files changed, 69 insertions, 10 deletions
| diff --git a/src/delivery_install.c b/src/delivery_install.c index 72f2663..6f745a7 100644 --- a/src/delivery_install.c +++ b/src/delivery_install.c @@ -82,18 +82,29 @@ int delivery_install_packages(struct Delivery *ctx, char *conda_install_dir, cha                          // We can't match on version here (index 0). The wheel's version is not guaranteed to be                          // equal to the tag; setuptools_scm auto-increments the value, the user can change it manually,                          // etc. -                        whl = get_wheel_file(ctx->storage.wheel_artifact_dir, info->name, +                        errno = 0; +                        whl = get_wheel_info(ctx->storage.wheel_artifact_dir, info->name,                                               (char *[]) {ctx->meta.python_compact, ctx->system.arch,                                                           "none", "any",                                                           post_commit, hash,                                                           NULL}, WHEEL_MATCH_ANY); - -                        guard_strlist_free(&tag_data); -                        info->version = whl->version; -                        sprintf(cmd + strlen(cmd), " '%s==%s'", info->name, whl->version); -                    } else { -                        sprintf(cmd + strlen(cmd), " '%s==%s'", info->name, info->version); +                        if (!whl && errno) { +                            // error +                            SYSERROR("Unable to read Python wheel info: %s\n", strerror(errno)); +                            exit(1); +                        } else if (!whl) { +                            // not found +                            fprintf(stderr, "No wheel packages found that match the description of '%s'", info->name); +                        } else { +                            // found +                            guard_strlist_free(&tag_data); +                            info->version = strdup(whl->version); +                        } +                        wheel_free(&whl);                      } +                    snprintf(cmd + strlen(cmd), +                             sizeof(cmd) - strlen(cmd) - strlen(info->name) - strlen(info->version) + 5, +                             " '%s==%s'", info->name, info->version);                  } else {                      fprintf(stderr, "Deferred package '%s' is not present in the tested package list!\n", name);                      return -1; diff --git a/src/wheel.c b/src/wheel.c index b96df57..4692d0a 100644 --- a/src/wheel.c +++ b/src/wheel.c @@ -1,6 +1,6 @@  #include "wheel.h" -struct Wheel *get_wheel_file(const char *basepath, const char *name, char *to_match[], unsigned match_mode) { +struct Wheel *get_wheel_info(const char *basepath, const char *name, char *to_match[], unsigned match_mode) {      DIR *dp;      struct dirent *rec;      struct Wheel *result = NULL; @@ -47,13 +47,41 @@ struct Wheel *get_wheel_file(const char *basepath, const char *name, char *to_ma          }          result = calloc(1, sizeof(*result)); +        if (!result) { +            SYSERROR("Unable to allocate %zu bytes for wheel struct", sizeof(*result)); +            closedir(dp); +            return NULL; +        } +          result->path_name = realpath(package_path, NULL); +        if (!result->path_name) { +            SYSERROR("Unable to resolve absolute path to %s: %s", filename, strerror(errno)); +            wheel_free(&result); +            closedir(dp); +            return NULL; +        }          result->file_name = strdup(rec->d_name); +        if (!result->file_name) { +            SYSERROR("Unable to allocate bytes for %s: %s", rec->d_name, strerror(errno)); +            wheel_free(&result); +            closedir(dp); +            return NULL; +        }          size_t parts_total;          char **parts = split(filename, "-", 0); +        if (!parts) { +            // This shouldn't happen unless a wheel file is present in the +            // directory with a malformed file name, or we've managed to +            // exhaust the system's memory +            SYSERROR("%s has no '-' separators! (Delete this file and try again)", filename); +            wheel_free(&result); +            closedir(dp); +            return NULL; +        } +          for (parts_total = 0; parts[parts_total] != NULL; parts_total++); -        if (parts_total < 6) { +        if (parts_total == 5) {              // no build tag              result->distribution = strdup(parts[0]);              result->version = strdup(parts[1]); @@ -61,7 +89,7 @@ struct Wheel *get_wheel_file(const char *basepath, const char *name, char *to_ma              result->python_tag = strdup(parts[2]);              result->abi_tag = strdup(parts[3]);              result->platform_tag = strdup(parts[4]); -        } else { +        } else if (parts_total == 6) {              // has build tag              result->distribution = strdup(parts[0]);              result->version = strdup(parts[1]); @@ -69,6 +97,13 @@ struct Wheel *get_wheel_file(const char *basepath, const char *name, char *to_ma              result->python_tag = strdup(parts[3]);              result->abi_tag = strdup(parts[4]);              result->platform_tag = strdup(parts[5]); +        } else { +            SYSERROR("Unknown wheel name format: %s. Expected 5 or 6 strings " +                     "separated by '-', but got %zu instead", filename, parts_total); +            GENERIC_ARRAY_FREE(parts); +            wheel_free(&result); +            closedir(dp); +            return NULL;          }          GENERIC_ARRAY_FREE(parts);          break; @@ -76,3 +111,16 @@ struct Wheel *get_wheel_file(const char *basepath, const char *name, char *to_ma      closedir(dp);      return result;  } + +void wheel_free(struct Wheel **wheel) { +    struct Wheel *w = (*wheel); +    guard_free(w->path_name); +    guard_free(w->file_name); +    guard_free(w->distribution); +    guard_free(w->version); +    guard_free(w->build_tag); +    guard_free(w->python_tag); +    guard_free(w->abi_tag); +    guard_free(w->python_tag); +    guard_free(w); +} | 
