From f39f85b16bb1a237af7b1989c9222309b230e902 Mon Sep 17 00:00:00 2001 From: Xylar Asay-Davis Date: Wed, 1 Mar 2023 23:29:08 +0100 Subject: [PATCH] Put spack specs in quotes to support version ranges --- conda/bootstrap.py | 21 +++++++++++---------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/conda/bootstrap.py b/conda/bootstrap.py index b038866dfe..48f8f4201c 100755 --- a/conda/bootstrap.py +++ b/conda/bootstrap.py @@ -397,7 +397,7 @@ def build_spack_env(config, update_spack, machine, compiler, mpi, spack_env, specs = list() if cmake != 'None': - specs.append(f'cmake@{cmake}') + specs.append(f'cmake "@{cmake}"') e3sm_hdf5_netcdf = config.getboolean('deploy', 'use_e3sm_hdf5_netcdf') if not e3sm_hdf5_netcdf: @@ -406,27 +406,28 @@ def build_spack_env(config, update_spack, machine, compiler, mpi, spack_env, netcdf_fortran = config.get('deploy', 'netcdf_fortran') pnetcdf = config.get('deploy', 'pnetcdf') specs.extend([ - f'hdf5@{hdf5}+cxx+fortran+hl+mpi+shared', - f'netcdf-c@{netcdf_c}+mpi~parallel-netcdf', - f'netcdf-fortran@{netcdf_fortran}', - f'parallel-netcdf@{pnetcdf}+cxx+fortran']) + f'hdf5 "@{hdf5}+cxx+fortran+hl+mpi+shared"', + f'netcdf-c "@{netcdf_c}+mpi~parallel-netcdf"', + f'netcdf-fortran "@{netcdf_fortran}"', + f'parallel-netcdf "@{pnetcdf}+cxx+fortran"']) if esmf != 'None': - specs.append(f'esmf@{esmf}+mpi+netcdf~pio+pnetcdf') + specs.append(f'esmf "@{esmf}+mpi+netcdf~pio+pnetcdf"') if lapack != 'None': - specs.append(f'netlib-lapack@{lapack}') + specs.append(f'netlib-lapack "@{lapack}"') include_e3sm_lapack = False else: include_e3sm_lapack = True if petsc != 'None': - specs.append(f'petsc@{petsc}+mpi+batch') + specs.append(f'petsc "@{petsc}+mpi+batch"') if scorpio != 'None': specs.append( - f'scorpio@{scorpio}+pnetcdf~timing+internal-timing~tools+malloc') + f'scorpio ' + f'"@{scorpio}+pnetcdf~timing+internal-timing~tools+malloc"') if albany != 'None': - specs.append(f'albany@{albany}+mpas') + specs.append(f'albany "@{albany}+mpas"') yaml_template = f'{spack_template_path}/{machine}_{compiler}_{mpi}.yaml' if not os.path.exists(yaml_template):