Opening a pull request¶
(for contributors)
To add software to EESSI, you should go through the semi-automatic software installation procedure by:
- 1) Making a pull request to the software-layer repository
     to (add or) update an easystack file that is used by EasyBuild to install software; 
- 2) Instructing the bot to build the software on all supported CPU microarchitectures; 
- 3) Instructing the bot to deploy the built software for ingestion into the EESSI repository; 
- 4) Merging the pull request once CI indicates that the software has been ingested. 
Warning
Make sure you are also aware of our contribution policy when adding software to EESSI.
Preparation¶
Before you can make a pull request to the software-layer, you should fork the repository in your GitHub account.
For the remainder of these instructions, we assume that your GitHub account is @koala .
Note
Don't forget to replace koala  with the name of your GitHub account in the commands below!
1) Clone the EESSI/software-layer repository:
2) Add your fork  as a remote
3) Make sure that you are on the main branch:
Note
The commands above only need to be run once, to prepare your setup for making pull requests.
Changes to EESSI/software-layer
On 2025-06-11 the EESSI/software-layer repository was split to primarily include    easystack files necessary for triggering builds. Most scripts needed to build the software have been moved to the new
repository EESSI/software-layer-scripts. In addition, 
installations to particular EESSI versions are no longer tracked by branches in 
EESSI/software-layer (e.g., the old 2023.06-software.eessi.io branch), but 
by editing or creating the easystack file in the corresponding directory (e.g., easystacks/software.eessi.io/2023.06/ to 
target version 2023.06).
Creating a pull request¶
1) Make sure that your main branch in the checkout of the
  EESSI/software-layer repository is up-to-date
2) Create a new branch (use a sensible name, not example_branch as below), and check it out
3) Determine the correct easystack file to change, and add one or more lines to it that specify which
   easyconfigs should be installed. Make sure that the easystack file is in the correct subdirectory. The structure should be easystacks/software.eessi.io/<eessi_version>/eessi-<eessi_version>/eb-<eb_version>-<toolchain_version>.yml:
echo '  - example-1.2.3-GCC-12.3.0.eb' >> easystacks/software.eessi.io/2023.06/eessi-2023.06-eb-5.1.1-2023a.yml
eessi-<eessi_version>-eb-<eb_version>-<toolchain_version>.yml. See the official EasyBuild documentation on easystack files for more information on the syntax.
4) Stage and commit the changes into your your branch with a sensible message
git add easystacks/software.eessi.io/2023.06/eessi-2023.06-eb-5.1.1-2023a.yml
git commit -m "{2023.06}[GCC/12.3.0] example 1.2.3"
5) Push your branch to your fork  of the software-layer repository
6) Go to the GitHub web interface to open your pull request,
   or use the helpful link that should show up in the output of the git push command.
Make sure you target the main branch.
Rebuilding software¶
We typically do not rebuild software, since (strictly speaking) this breaks reproducibility for anyone using it. However, there are certain situations in which it is difficult or impossible to avoid.
To do a rebuild, you add the software you want to rebuild to a dedicated easystack file in the rebuilds subdirectory inside each version's directory. Use the following naming convention: YYYYMMDD-eb-<EB_VERSION>-<APPLICATION_NAME>-<APPLICATION_VERSION>-<SHORT_DESCRIPTION>.yml, where YYYYMMDD is the opening date of your PR. E.g. 20240506-eb-4.9.1-CUDA-12.1.1-ship-full-runtime.yml was added in a PR on the 6th of May 2024 and used to rebuild CUDA-12.1.1 using EasyBuild 4.9.1 to resolve an issue with some runtime libraries missing from the initial CUDA 12.1.1 installation.
At the top of your easystack file, please use comments to include a short description, and make sure to include any relevant links to related issues (e.g. from the GitHub repositories of EESSI, EasyBuild, or the software you are rebuilding).
As an example, consider the full easystack file (20240506-eb-4.9.1-CUDA-12.1.1-ship-full-runtime.yml) used for the aforementioned CUDA rebuild: 
# 2024.05.06
# Original matching of files we could ship was not done correctly. We were
# matching the basename for files (e.g., libcudart.so from libcudart.so.12)
# rather than the name stub (libcudart)
# See https://github.com/EESSI/software-layer/pull/559
easyconfigs:
  - CUDA-12.1.1.eb:
        options:
                accept-eula-for: CUDA
By separating rebuilds in dedicated files, we still maintain a complete software bill of materials: it is transparent what got rebuilt, for which reason, and when.