Making software available via a custom module file
If you wish to use the modules system with personal
module files you can add a directory called modules to your home directory
mkdir $HOME/modules
and populate this with your own module files.
To make these available automatically you can then add the module use $HOME/modules
command to your .bashrc
file.
You can generate a basic module file using the basic Lua directives to set local
variables,
export these to your shell with the setenv
function and prepend paths to your existing environment
variables with the prepend_path
function.
Warning
Module files are not aware of bash shell variables unless you import them using the os.getenv
function and set a Lua variable based on them.
e.g. the following example imports our shell environment HOME
variable and sets the Lua
HOME
variable with it. The Lua HOME
variable is used to set the Lua variable MY_PROGRAM_DIR
(the software’s installation directory). The Lua MY_PROGRAM_DIR
variable is then used to add the program’s
bin
directory to your shell environment PATH
variable with the prepend_path
function.
-- Import the shell environment HOME variable into a Lua variable.
local HOME = os.getenv("HOME")
-- Set a local Lua variable for the program directory.
local MY_PROGRAM_DIR = HOME .. "/software/installs/my_new_program"
-- Export the program directory to the shell environment.
setenv("MY_PROGRAM_DIR", MY_PROGRAM_DIR)
-- Prepend the program's bin directory to the shell environment PATH variable.
prepend_path("PATH", MY_PROGRAM_DIR .. "/bin")
Much like using a .bashrc
file with the export command, we can add the required variables and directives
to a custom module file. For example, if called CustomModule
and saved in $HOME/modules/
may
look something like:
------------------------------------------------------------------------------------------------
/users/my_username/modules/my_new_program.lua:
------------------------------------------------------------------------------------------------
-- Provide help text for the module.
help([[
Description
===========
Makes my newly installed program available.
More information
================
- Homepage: https://www.my-new-programme.com
]])
-- Describe the module.
whatis("Description: Makes my newly installed program available.")
whatis("Homepage: https://www.my-new-programme.com")
whatis("URL: https://www.my-new-programme.com")
-- Specify a conflicting module.
conflict("CustomModule")
-- Load any dependencies.
load("GCC/10.2")
load("CMake/3.18.4-GCCcore-10.2.0")
-- Set a program root directory Lua variable MY_PROGRAM_DIR to simplify prepend_path directives.
-- Reminder: setting an environment variable with setenv does not set the equivalent Lua variable!
-- Reminder: setting a Lua variable does not set the equivalent shell environment variable either!
-- Note no trailing slash is required for MY_PROGRAM_DIR as we are using a / on the prepend_path directives.
local MY_PROGRAM_DIR = "/users/my_username/software/installs/my_new_program"
setenv("MY_PROGRAM_DIR", MY_PROGRAM_DIR)
setenv("MY_SOFTWARE_LICENSE_PATH", "/users/my_username/software/licenses/mysoftware/license.lic")
-- Add directories to environment variables.
prepend_path("PATH", pathJoin(MY_PROGRAM_DIR, "bin"))
prepend_path("LIBRARY_PATH", pathJoin(MY_PROGRAM_DIR, "lib"))
prepend_path("LD_LIBRARY_PATH", pathJoin(MY_PROGRAM_DIR, "lib"))
prepend_path("PKG_CONFIG_PATH", pathJoin(MY_PROGRAM_DIR, "lib/pkgconfig"))
prepend_path("CMAKE_PREFIX_PATH", MY_PROGRAM_DIR)
You can generate a basic module file using the basic TCL directives to set
variables,
export these to your shell with setenv
and prepend paths to your existing environment
variables with prepend-path
.
Warning
Module files are not aware of bash shell variables unless you import them from the env array and set a TCL variable based on them.
e.g. the following example imports our shell environment HOME
variable and sets the TCL
HOME
variable with it. The TCL HOME
variable is used to set the TCL variable MY_PROGRAM_DIR
(the software’s installation directory). The TCL MY_PROGRAM_DIR
variable is then used to add the program’s
bin
directory to your shell environment PATH
variable with the prepend-path
directive.
set HOME $::env(HOME)
set MY_PROGRAM_DIR $HOME/software/installs/my_new_program
prepend-path PATH $MY_PROGRAM_DIR/bin
Much like using a .bashrc
file with the export command, we can add the required variables and directives
to a custom module file. For example, if called CustomModule
and saved in $HOME/modules/
may
look something like:
#%Module1.0#####################################################################
##
## My newly installed program module file
##
## Module file logging - this is TUoS cluster specific!
source /usr/local/etc/module_logging.tcl
##
proc ModulesHelp { } {
puts stderr "Makes my newly installed program available."
}
module-whatis "Makes my newly installed program available."
## Load any dependencies
module load GCC/10.2
module load CMake/3.18.4-GCCcore-10.2.0
## Set a program root directory TCL variable MY_PROGRAM_DIR to simplify prepend-path directives.
## **Reminder** setting an environment variable with setenv does not set the equivalent TCL variable!
## **Reminder** setting a TCL variable does not set the equivalent shell environment variable either!
## Note no trailing slash is required for MY_PROGRAM_DIR as we are using a / on the prepend-path directives.
set MY_PROGRAM_DIR /home/my_username/software/installs/my_new_program
setenv MY_PROGRAM_DIR $MY_PROGRAM_DIR
setenv MY_SOFTWARE_LICENSE_PATH /home/my_username/software/licenses/mysoftware/license.lic
prepend-path PATH $MY_PROGRAM_DIR/bin
prepend-path LIBRARY_PATH $MY_PROGRAM_DIR/lib
prepend-path LD_LIBRARY_PATH $MY_PROGRAM_DIR/lib
prepend-path PKG_CONFIG_PATH $MY_PROGRAM_DIR/lib/pkgconfig
prepend-path CMAKE_PREFIX_PATH $MY_PROGRAM_DIR
Hint
If you get warnings about missing file paths please ensure the file path exists and/or you have not made a mistake
when defining your TCL variables. (Remember the difference between set
and setenv
directives and that one
does not set the other.)
If the module use command (module use $HOME/modules
) is applied in your .bashrc
file you could now load this module by running:
$ module load CustomModule
And unload with:
$ module unload CustomModule
Modulefiles make it easy to add many versions of the same software easily via duplication and simple editing without the risk of permanently corrupting your shell environment. Further info on the modules system can be found on the modules page.