Currently tested on:
- Ubuntu 20.04
- Ubuntu 22.04
- CentOS 7
- AlmaLinux 8
- Rocky Linux 8
- Rocky Linux 9
- Debian 11
- Debian 12
This repository is expected to build in a VM or container environment that is isolated from other software or build environments. Pre-written dockerfiles can be found in the development environment repository.
The automated scripts run commands as sudo
and update system libraries and compilers, etc.
In a new container, run the following:
apt-get update
apt-get install -y sudo git python3 python3-distro
./install_prerequisites.py
# The following lines apply to Ubuntu 20 only!!!
update-alternatives --install /usr/local/bin/gcc gcc /usr/bin/gcc-10 1
update-alternatives --install /usr/local/bin/g++ g++ /usr/bin/g++-10 1
hash -r
make # or "make server" for packages specific to building the iRODS server.
yum install -y sudo git python3 centos-release-scl epel-release
yum install -y python36-distro devtoolset-10-gcc devtoolset-10-gcc-c++
# Installing the prerequistes must be done before enabling the GCC compiler
# environment.
./install_prerequisites.py
# Enable the GCC 10 compiler tools.
scl enable devtoolset-10 bash
make # or "make server" for packages specific to building the iRODS server.
dnf config-manager --set-enabled powertools
dnf install -y sudo git python3 python3-distro gcc-toolset-11
# Installing the prerequistes must be done before enabling the GCC compiler
# environment.
./install_prerequisites.py
# Enable the GCC 11 compiler tools.
scl enable gcc-toolset-11 bash
make # or "make server" for packages specific to building the iRODS server.
dnf config-manager --set-enabled crb
dnf install -y sudo git python3 python3-distro
./install_prerequisites.py
make # or "make server" for packages specific to building the iRODS server.
Yes. Open versions.json
, find the package of interest, and set the "git_repository"
property to the URL of the repository to clone. If this property is not present, it means the build will clone the forked repository under https://github.com/irods. The build expects that the clone will have a directory name matching the name of the forked project under https://github.com/irods.
Defining a different git repository to use for an external normally means a change in the version. For that reason, it is important to remember that "commitish"
is required to match a branch name or tag. If you want to use a SHA for the "commitish"
, you'll need to set "enable_sha"
to true
. This instructs the build system to separate the fetching/checking-out of a commit from the cloning of the repository. To better explain what this means, see below.
If "enable_sha"
is set to false
or isn't defined for a package, the build system will do the following:
$ git clone --depth 1 --branch <branch_name_or_tag> --recurse-submodules <git_repository>
If "enable_sha"
is set to true
, the build system will do this instead:
$ git clone --recurse-submodules <git_repository>
$ cd <git_repository>
$ git fetch
$ git checkout <sha> # Or branch name, or tag.