This repo serves to build all the needed LightGBM artifacts to create a Java library, including a copy of OpenMP's .so, from a "replica" of LightGBM's CI build environment that does not require Microsoft credentials.
- bash & sed
- docker
- git
To generate the build/
folder with all necessary artifacts just run:
bash make.sh [lightgbm_version] [package_version] # where lightgbm_version is any of (commit_id, tag, branch)
In case it fails compiling for ARM64 you may need to run:
docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
If no lightgbm_version
is specified, master
is checked out.
If no package_version
is specified:
- If
lightgbm_version
is a release (vMAJOR.MINOR.PATCH
),package_version=MAJOR.MINOR.PATCH
. Otherwise,package_version=0.0.0
.
Finally, in the output pom.xml
, the package version is the one specified in package_version
, except if it is 0.0.0
. In that case the build version becomes package_version-lightgbm_version
.
By defining the environment variable LIGHTGBM_REPO_URL
which by default points to LightGBM, to another http(s)
git LightGBM repo URL, you can build your own custom version of LightGBM. This can be useful to try building our own patched/custom versions of LightGBM. Ensure you use the http(s) protocol instead of git.
In case you want to build only for AMD64, which doesn't have to use qemu emulation, you must define the environment variable ARCH_BUILD=single
prior to running make.sh
.
This is the output:
build
├── amd64
│ ├── glibc
│ │ ├── libgomp.so.1.0.0
│ │ ├── lib_lightgbm.so
│ │ └── lib_lightgbm_swig.so
│ ├── musl
│ │ ├── libgomp.so.1.0.0
│ │ ├── lib_lightgbm.so
│ │ └── lib_lightgbm_swig.so
├── arm64
│ ├── libgomp.so.1.0.0
│ ├── lib_lightgbm.so
│ └── lib_lightgbm_swig.so
├── __commit_id__
├── install_jar_locally.sh
├── libopenmp.licence
├── lightgbmlib.jar
├── __lightgbm_repo_url__
├── pom.xml
├── __timestamp__
└── __version__
Files with "__" are just single-line files containing meta-data for traceability so you don't lose track of build conditions.
You can now copy this folder into your project and either run bash install_jar_locally.sh
or use maven's install plugin.
This explains how to build local patches from source for LightGBM. This allows quicker iterations during LightGBM C++ development/debugging.
For instance, to perform debugging, one must build LightGBM using the compiler toolchain available on the target machine running the debugger, otherwise there will be symbol compatibility issues.
Patching is done in a two-stage process:
- Run at least once the base
make.sh
to have the base build. - Patch the base build by calling
make_patch.sh
as explained below.
First, clone the LightGBM repo/fork to your computer and run CMake with the desired flags:
cd my_lgbm_repo
mkdir build
cd build
cmake .. -DUSE_DEBUG=ON -DUSE_SWIG=ON
Note
The patch only applies to AMD64 builds. It doesn't change other architectures' builds (e.g., ARM64)
After the CMake setup is complete, simply run make_patch.sh
against that folder:
bash make_patch.sh my_lgbm_repo_build_folder
This will compile LightGBM from source with your settings and patch the current base LightGBM build in the provider.
Run make_patch.sh
every time you want to build a new patch.