diff options
| author | Joseph Hunkeler <jhunkeler@gmail.com> | 2024-04-02 18:35:34 -0400 | 
|---|---|---|
| committer | Joseph Hunkeler <jhunkeler@gmail.com> | 2024-04-02 18:55:48 -0400 | 
| commit | c6916091d97d173628a1c6173b0cf3b0cbd13355 (patch) | |
| tree | 8fd12196c475d622a8bff9d658fcbe050776fa4c /src/deliverable.c | |
| parent | 2edc9d2a9d83127ca31fb656be3b4a086124e334 (diff) | |
| download | stasis-c6916091d97d173628a1c6173b0cf3b0cbd13355.tar.gz | |
Reenable installation via local wheels
Diffstat (limited to 'src/deliverable.c')
| -rw-r--r-- | src/deliverable.c | 60 | 
1 files changed, 33 insertions, 27 deletions
| diff --git a/src/deliverable.c b/src/deliverable.c index d707c21..d7ca722 100644 --- a/src/deliverable.c +++ b/src/deliverable.c @@ -991,33 +991,39 @@ int delivery_install_packages(struct Delivery *ctx, char *conda_install_dir, cha                  continue;              }              if (INSTALL_PKG_PIP_DEFERRED & type) { -                //DIR *dp; -                //struct dirent *rec; - -                //dp = opendir(ctx->storage.wheel_artifact_dir); -                //if (!dp) { -                //    perror(ctx->storage.wheel_artifact_dir); -                //    exit(1); -                //} - -                //char pyver_compact[100]; -                //sprintf(pyver_compact, "-cp%s", ctx->meta.python); -                //strchrdel(pyver_compact, "."); -                //while ((rec = readdir(dp)) != NULL) { -                //    struct Wheel *wheelfile = NULL; -                //    if (!strcmp(rec->d_name, ".") || !strcmp(rec->d_name, "..")) { -                //        continue; -                //    } -                //    if (DT_DIR == rec->d_type && startswith(rec->d_name, name)) { -                //        wheelfile = get_wheel_file(ctx->storage.wheel_artifact_dir, name, (char *[]) {pyver_compact, NULL}); -                //        if (wheelfile) { -                //            sprintf(cmd + strlen(cmd), " %s/%s", wheelfile->path_name, wheelfile->file_name); -                //            free(wheelfile); -                //            break; -                //        } -                //    } -                //} -                //closedir(dp); +                DIR *dp; +                struct dirent *rec; + +                dp = opendir(ctx->storage.wheel_artifact_dir); +                if (!dp) { +                    perror(ctx->storage.wheel_artifact_dir); +                    exit(1); +                } + +                char pyver_compact[100]; +                sprintf(pyver_compact, "-cp%s", ctx->meta.python_compact); +                while ((rec = readdir(dp)) != NULL) { +                    struct Wheel *wheelfile = NULL; +                    if (!strcmp(rec->d_name, ".") || !strcmp(rec->d_name, "..")) { +                        continue; +                    } +                    if (DT_DIR == rec->d_type && startswith(rec->d_name, name)) { +                        wheelfile = get_wheel_file(ctx->storage.wheel_artifact_dir, name, (char *[]) {pyver_compact, NULL}); +                        if (!wheelfile) { +                            // Not a binary package? Let's check. +                            wheelfile = get_wheel_file(ctx->storage.wheel_artifact_dir, name, (char *[]) {"-any", NULL}); +                        } +                        if (wheelfile) { +                            sprintf(cmd + strlen(cmd), " %s/%s", wheelfile->path_name, wheelfile->file_name); +                            free(wheelfile); +                            break; +                        } else { +                            fprintf(stderr, "Delivery artifact for '%s' is not present in '%s'!\n", name, ctx->storage.wheel_artifact_dir); +                            exit(1); +                        } +                    } +                } +                closedir(dp);                  char *requirement = requirement_from_test(ctx, name);                  if (requirement) {                      sprintf(cmd + strlen(cmd), " '%s'", requirement); | 
