d9505a4527 | ||
---|---|---|
.. | ||
scripts | ||
README.md | ||
init_caches.sh | ||
use_caches.sh |
README.md
Building LAMMPS and its documentation on offline systems
In some situations it might be necessary to build LAMMPS on a system without internet. The scripts in this folder allow you to preload external dependencies for both the documentation build and for building with CMake.
It does so by
- Downloading necessary pip packages
- Cloning git repositories
- Downloading tarballs
As of April 2021, all of these downloads make up around 600MB. By
default, it will download everything into $HOME/.cache/lammps, but this can be
changed with the LAMMPS_CACHING_DIR
environment variable.
Once the caches have been initialized, they can be used for building LAMMPS documentation or compiling using CMake on an offline system.
The use_caches.sh
must be sourced into the current shell to initialize the
offline build environment. Note that it must use the same LAMMPS_CACHING_DIR
.
This script does the following:
- Sets up environment variables that modify the behavior of both pip and git
- Starts a simple local HTTP server to host files for CMake
Afterwards, it will print out instruction on how to modify the CMake command line to make sure it uses the local HTTP server.
To undo the environment changes and shutdown the local HTTP server, run the
deactivate_caches
command.
Examples
For all of the examples below, you first need to create the cache, which requires an internet connection.
./tools/offline/init_caches.sh
Afterwards, you can disconnect or copy the contents of the LAMMPS_CACHING_DIR
folder to an offline system.
Documentation
The documentation build will create a new virtual environment that typically first installs dependencies from pip. With the offline environment loaded, these installations will instead grab the necessary packages from your local cache.
# if LAMMPS_CACHING_DIR is different from default, make sure to set it first
# export LAMMPS_CACHING_DIR=path/to/folder
source tools/offline/use_caches.sh
cd doc/
make html
deactivate_caches
CMake Build
When compiling certain packages with external dependencies, the CMake build system will download some things from the web.
For more flexibility it allows users to specify the URL of each of these dependencies. What the init_caches.sh
script does is
create a CMake preset file, which sets the URL for all of the known dependencies and redirects the download to a local cache.
# if LAMMPS_CACHING_DIR is different from default, make sure to set it first
# export LAMMPS_CACHING_DIR=path/to/folder
source tools/offline/use_caches.sh
mkdir build
cd build
cmake -D LAMMPS_DOWNLOADS_URL=${HTTP_CACHE_URL} -C "${LAMMPS_HTTP_CACHE_CONFIG}" -C ../cmake/presets/most.cmake ../cmake
make -j 8
deactivate_caches