"git@developer.sourcefind.cn:tianlh/lightgbm-dcu.git" did not exist on "4eb0745d9a24fb5f29e3fcb357d847fc4a3d7f53"
Unverified Commit 59a3432b authored by Nikita Titov's avatar Nikita Titov Committed by GitHub
Browse files

[cmake] simplify SWIG config (#6648)


Co-authored-by: default avatarJames Lamb <jaylamb20@gmail.com>
parent 696b9048
...@@ -59,10 +59,10 @@ if(__INTEGRATE_OPENCL) ...@@ -59,10 +59,10 @@ if(__INTEGRATE_OPENCL)
message(STATUS "Building library with integrated OpenCL components") message(STATUS "Building library with integrated OpenCL components")
endif() endif()
if(__BUILD_FOR_PYTHON OR __BUILD_FOR_R) if(__BUILD_FOR_PYTHON OR __BUILD_FOR_R OR USE_SWIG)
# the Python and R package don't require the CLI # the SWIG wrapper, the Python and R package don't require the CLI
set(BUILD_CLI OFF) set(BUILD_CLI OFF)
# installing the R and Python package shouldn't place LightGBM's headers # installing the SWIG wrapper, the R and Python package shouldn't place LightGBM's headers
# outside of where the package is installed # outside of where the package is installed
set(INSTALL_HEADERS OFF) set(INSTALL_HEADERS OFF)
endif() endif()
...@@ -104,15 +104,16 @@ if(USE_SWIG) ...@@ -104,15 +104,16 @@ if(USE_SWIG)
include_directories(JNI_INCLUDE_DIRS) include_directories(JNI_INCLUDE_DIRS)
include_directories($ENV{JAVA_HOME}/include) include_directories($ENV{JAVA_HOME}/include)
if(WIN32) if(WIN32)
file(MAKE_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/com/microsoft/ml/lightgbm/windows/x86_64") set(LGBM_SWIG_DESTINATION_DIR "${CMAKE_CURRENT_BINARY_DIR}/com/microsoft/ml/lightgbm/windows/x86_64")
include_directories($ENV{JAVA_HOME}/include/win32) include_directories($ENV{JAVA_HOME}/include/win32)
elseif(APPLE) elseif(APPLE)
file(MAKE_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/com/microsoft/ml/lightgbm/osx/x86_64") set(LGBM_SWIG_DESTINATION_DIR "${CMAKE_CURRENT_BINARY_DIR}/com/microsoft/ml/lightgbm/osx/x86_64")
include_directories($ENV{JAVA_HOME}/include/darwin) include_directories($ENV{JAVA_HOME}/include/darwin)
else() else()
file(MAKE_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/com/microsoft/ml/lightgbm/linux/x86_64") set(LGBM_SWIG_DESTINATION_DIR "${CMAKE_CURRENT_BINARY_DIR}/com/microsoft/ml/lightgbm/linux/x86_64")
include_directories($ENV{JAVA_HOME}/include/linux) include_directories($ENV{JAVA_HOME}/include/linux)
endif() endif()
file(MAKE_DIRECTORY "${LGBM_SWIG_DESTINATION_DIR}")
endif() endif()
set(EIGEN_DIR "${PROJECT_SOURCE_DIR}/external_libs/eigen") set(EIGEN_DIR "${PROJECT_SOURCE_DIR}/external_libs/eigen")
...@@ -542,65 +543,23 @@ if(USE_SWIG) ...@@ -542,65 +543,23 @@ if(USE_SWIG)
OUTPUT_NAME "lib_lightgbm_swig" OUTPUT_NAME "lib_lightgbm_swig"
) )
if(WIN32) if(WIN32)
set(LGBM_SWIG_LIB_DESTINATION_PATH "${LGBM_SWIG_DESTINATION_DIR}/lib_lightgbm_swig.dll")
if(MINGW OR CYGWIN) if(MINGW OR CYGWIN)
add_custom_command( set(LGBM_LIB_SOURCE_PATH "${PROJECT_SOURCE_DIR}/lib_lightgbm.dll")
TARGET _lightgbm_swig set(LGBM_SWIG_LIB_SOURCE_PATH "${PROJECT_SOURCE_DIR}/lib_lightgbm_swig.dll")
POST_BUILD
COMMAND "${Java_JAVAC_EXECUTABLE}" -d . java/*.java
COMMAND
"${CMAKE_COMMAND}"
-E
copy_if_different
"${PROJECT_SOURCE_DIR}/lib_lightgbm.dll"
com/microsoft/ml/lightgbm/windows/x86_64
COMMAND
"${CMAKE_COMMAND}"
-E
copy_if_different
"${PROJECT_SOURCE_DIR}/lib_lightgbm_swig.dll"
com/microsoft/ml/lightgbm/windows/x86_64
COMMAND "${Java_JAR_EXECUTABLE}" -cf lightgbmlib.jar com
)
else() else()
add_custom_command( set(LGBM_LIB_SOURCE_PATH "${PROJECT_SOURCE_DIR}/Release/lib_lightgbm.dll")
TARGET _lightgbm_swig set(LGBM_SWIG_LIB_SOURCE_PATH "${PROJECT_SOURCE_DIR}/Release/lib_lightgbm_swig.dll")
POST_BUILD
COMMAND "${Java_JAVAC_EXECUTABLE}" -d . java/*.java
COMMAND
"${CMAKE_COMMAND}"
-E
copy_if_different
"${PROJECT_SOURCE_DIR}/Release/lib_lightgbm.dll"
com/microsoft/ml/lightgbm/windows/x86_64
COMMAND
"${CMAKE_COMMAND}"
-E
copy_if_different
"${PROJECT_SOURCE_DIR}/Release/lib_lightgbm_swig.dll"
com/microsoft/ml/lightgbm/windows/x86_64
COMMAND "${Java_JAR_EXECUTABLE}" -cf lightgbmlib.jar com
)
endif() endif()
elseif(APPLE) elseif(APPLE)
add_custom_command( set(LGBM_LIB_SOURCE_PATH "${PROJECT_SOURCE_DIR}/lib_lightgbm.dylib")
TARGET _lightgbm_swig set(LGBM_SWIG_LIB_SOURCE_PATH "${PROJECT_SOURCE_DIR}/lib_lightgbm_swig.jnilib")
POST_BUILD set(LGBM_SWIG_LIB_DESTINATION_PATH "${LGBM_SWIG_DESTINATION_DIR}/lib_lightgbm_swig.dylib")
COMMAND "${Java_JAVAC_EXECUTABLE}" -d . java/*.java
COMMAND
"${CMAKE_COMMAND}"
-E
copy_if_different
"${PROJECT_SOURCE_DIR}/lib_lightgbm.dylib"
com/microsoft/ml/lightgbm/osx/x86_64
COMMAND
"${CMAKE_COMMAND}"
-E
copy_if_different
"${PROJECT_SOURCE_DIR}/lib_lightgbm_swig.jnilib"
com/microsoft/ml/lightgbm/osx/x86_64/lib_lightgbm_swig.dylib
COMMAND "${Java_JAR_EXECUTABLE}" -cf lightgbmlib.jar com
)
else() else()
set(LGBM_LIB_SOURCE_PATH "${PROJECT_SOURCE_DIR}/lib_lightgbm.so")
set(LGBM_SWIG_LIB_SOURCE_PATH "${PROJECT_SOURCE_DIR}/lib_lightgbm_swig.so")
set(LGBM_SWIG_LIB_DESTINATION_PATH "${LGBM_SWIG_DESTINATION_DIR}/lib_lightgbm_swig.so")
endif()
add_custom_command( add_custom_command(
TARGET _lightgbm_swig TARGET _lightgbm_swig
POST_BUILD POST_BUILD
...@@ -609,17 +568,16 @@ if(USE_SWIG) ...@@ -609,17 +568,16 @@ if(USE_SWIG)
"${CMAKE_COMMAND}" "${CMAKE_COMMAND}"
-E -E
copy_if_different copy_if_different
"${PROJECT_SOURCE_DIR}/lib_lightgbm.so" "${LGBM_LIB_SOURCE_PATH}"
com/microsoft/ml/lightgbm/linux/x86_64 "${LGBM_SWIG_DESTINATION_DIR}"
COMMAND COMMAND
"${CMAKE_COMMAND}" "${CMAKE_COMMAND}"
-E -E
copy_if_different copy_if_different
"${PROJECT_SOURCE_DIR}/lib_lightgbm_swig.so" "${LGBM_SWIG_LIB_SOURCE_PATH}"
com/microsoft/ml/lightgbm/linux/x86_64 "${LGBM_SWIG_LIB_DESTINATION_PATH}"
COMMAND "${Java_JAR_EXECUTABLE}" -cf lightgbmlib.jar com COMMAND "${Java_JAR_EXECUTABLE}" -cf lightgbmlib.jar com
) )
endif()
endif() endif()
if(USE_MPI) if(USE_MPI)
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment