From 617c1a37060b975d12f8bfa4bdfd0acb0fa8a2d0 Mon Sep 17 00:00:00 2001 From: Michael Kuhn Date: Thu, 28 Feb 2019 13:22:44 +0100 Subject: Fix shell integration with environment-modules@4 (#10736) --- share/spack/setup-env.sh | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) (limited to 'share') diff --git a/share/spack/setup-env.sh b/share/spack/setup-env.sh index f82a55d8f1..19bb3e24e8 100755 --- a/share/spack/setup-env.sh +++ b/share/spack/setup-env.sh @@ -272,10 +272,16 @@ if [ "${need_module}" = "yes" ]; then # _sp_module_prefix is set by spack --print-sh-vars if [ "${_sp_module_prefix}" != "not_installed" ]; then - #activate it! - export MODULE_PREFIX=${_sp_module_prefix} - _spack_pathadd PATH "${MODULE_PREFIX}/Modules/bin" - module() { eval `${MODULE_PREFIX}/Modules/bin/modulecmd ${SPACK_SHELL} $*`; } + # activate it! + # environment-modules@4: has a bin directory inside its prefix + MODULE_PREFIX_BIN="${_sp_module_prefix}/bin" + if [ ! -d "${MODULE_PREFIX_BIN}" ]; then + # environment-modules@3 has a nested bin directory + MODULE_PREFIX_BIN="${_sp_module_prefix}/Modules/bin" + fi + export MODULE_PREFIX_BIN + _spack_pathadd PATH "${MODULE_PREFIX_BIN}" + module() { eval `${MODULE_PREFIX_BIN}/modulecmd ${SPACK_SHELL} $*`; } fi; else eval `spack --print-shell-vars sh` -- cgit v1.2.3-70-g09d2