From 73a7b2c4851a62e57e9265ed3502dcd6cb8f461f Mon Sep 17 00:00:00 2001 From: Xylar Asay-Davis Date: Tue, 22 Mar 2022 10:47:42 +0100 Subject: [PATCH] Add arg for specifying spack temp. directory This is useful if the default (`/tmp`) tends to run out of space. --- mache/spack/__init__.py | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/mache/spack/__init__.py b/mache/spack/__init__.py index 8540c86a..fefb8e0b 100644 --- a/mache/spack/__init__.py +++ b/mache/spack/__init__.py @@ -10,7 +10,7 @@ def make_spack_env(spack_path, env_name, spack_specs, compiler, mpi, machine=None, include_e3sm_hdf5_netcdf=False, - yaml_template=None): + yaml_template=None, tmpdir=None): """ Clone the ``spack_for_mache_{{version}}`` branch from `E3SM's spack clone `_ and build @@ -46,6 +46,9 @@ def make_spack_env(spack_path, env_name, spack_specs, compiler, mpi, A jinja template for a yaml file to be used for the environment instead of the mache template. This allows you to use compilers and other modules that differ from E3SM. + + tmpdir : str, optional + A temporary directory for building spack packages """ if machine is None: @@ -94,6 +97,10 @@ def make_spack_env(spack_path, env_name, spack_specs, compiler, mpi, template = Template( resources.read_text('mache.spack', 'build_spack_env.template')) + if tmpdir is not None: + modules = f'{modules}\n' \ + f'export TMPDIR={tmpdir}' + build_file = template.render(modules=modules, version=__version__, spack_path=spack_path, env_name=env_name, yaml_filename=yaml_filename)