diff options
| author | Joseph Hunkeler <jhunkeler@gmail.com> | 2024-10-04 08:48:00 -0400 | 
|---|---|---|
| committer | Joseph Hunkeler <jhunkeler@gmail.com> | 2024-10-04 08:48:00 -0400 | 
| commit | 485de019d37dd712ce62ea2193d461f701a70df1 (patch) | |
| tree | 5e70eb0f25c04e4b44ecc470e34be17d12aaedeb | |
| parent | d7e3deba72703ad36c497f5becf6772ca00a0d6d (diff) | |
| download | stasis-485de019d37dd712ce62ea2193d461f701a70df1.tar.gz | |
Add conda_get_active_environment() functionconda-get-active-environment
| -rw-r--r-- | include/conda.h | 5 | ||||
| -rw-r--r-- | src/conda.c | 33 | 
2 files changed, 38 insertions, 0 deletions
| diff --git a/include/conda.h b/include/conda.h index c546672..b5ea926 100644 --- a/include/conda.h +++ b/include/conda.h @@ -192,4 +192,9 @@ int conda_index(const char *path);   */  int pip_index_provides(const char *index_url, const char *name, const char *version); +char *conda_get_active_environment(); + +int conda_provides(const char *spec); + +  #endif //STASIS_CONDA_H diff --git a/src/conda.c b/src/conda.c index 37a7793..43b9001 100644 --- a/src/conda.c +++ b/src/conda.c @@ -437,6 +437,39 @@ int conda_env_export(char *name, char *output_dir, char *output_filename) {      return conda_exec(env_command);  } +char *conda_get_active_environment() { +    const char *name = getenv("CONDA_DEFAULT_ENV"); +    if (!name) { +        return NULL; +    } + +    char *result = NULL; +    result = strdup(name); +    if (!result) { +        return NULL; +    } + +    return result; +} + +int conda_provides(const char *spec) { +    struct Process proc; +    memset(&proc, 0, sizeof(proc)); +    strcpy(proc.f_stdout, "/dev/null"); +    strcpy(proc.f_stderr, "/dev/null"); + +    // It's worth noting the departure from using conda_exec() here: +    // conda_exec() expects the program output to be visible to the user. +    // For this operation we only need the exit value. +    char cmd[PATH_MAX] = {0}; +    snprintf(cmd, sizeof(cmd) - 1, "mamba search --use-index-cache %s", spec); +    if (shell(&proc, cmd) < 0) { +        fprintf(stderr, "shell: %s", strerror(errno)); +        return -1; +    } +    return proc.returncode == 0; +} +  int conda_index(const char *path) {      char command[PATH_MAX];      sprintf(command, "index %s", path); | 
