I have legacy C++ code that is built using CMake. It generates a .so
file. I need to wrap this code in Java and build a jar
that includes Java code as
In Apache Hadoop, the build does something similar to what you described.
We use the Apache Maven AntRun Plugin during the compile phase to make an external call to cmake
and then call make
on the build output generated by CMake to compile and link the C portion of our codebase. This output then feeds into our final build artifacts. In our case, those build artifacts are tarballs rather than bundled straight into a jar file, but you could accomplish it by controlling configuration of the Apache Maven JAR Plugin. Specifically, you may need to override content include/exclude settings.
If you'd like to use it as a starting point, the relevant part of the Hadoop build is visible here:
https://github.com/apache/hadoop/blob/release-2.7.3-RC2/hadoop-common-project/hadoop-common/pom.xml#L598-L615
make
compile
run