X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/cb56175c151164814ba050079ebc4ff9040eb9ea..82c8c18086305a434d8965730f7a1ea93ddf141d:/tools/cmake/Java.cmake diff --git a/tools/cmake/Java.cmake b/tools/cmake/Java.cmake index 71d4b850e5..8e0ee2ffd2 100644 --- a/tools/cmake/Java.cmake +++ b/tools/cmake/Java.cmake @@ -3,9 +3,27 @@ ## This file is loaded only if the Java option is activated ## -find_package(Java 1.7 REQUIRED) +find_package(Java 1.7 COMPONENTS Runtime Development) +if (NOT ${Java_FOUND}) + message(FATAL_ERROR "Java not found (need at least Java7). Please install the JDK or disable that option") +endif() +set(Java_FOUND 1) include(UseJava) +find_package(JNI REQUIRED) +message("-- [Java] JNI found: ${JNI_FOUND}") +message("-- [Java] JNI include dirs: ${JNI_INCLUDE_DIRS}") + +find_package(SWIG) +if(${SWIG_FOUND}) + include(UseSWIG) + message("-- [Java] Swig found: version ${SWIG_VERSION}") +else() + message("-- [Java] Swig NOT FOUND. Surf java bindings won't get refreshed. That's fine unless you work on this part yourself.") +endif() +mark_as_advanced(SWIG_EXECUTABLE) + + # Rules to build libsimgrid-java # add_library(simgrid-java SHARED ${JMSG_C_SRC}) @@ -83,11 +101,6 @@ add_custom_command( ### if(enable_lib_in_jar) - find_program(STRIP_COMMAND strip) - mark_as_advanced(STRIP_COMMAND) - if(NOT STRIP_COMMAND) - set(STRIP_COMMAND "cmake -E echo (strip not found)") - endif() set(SG_SYSTEM_NAME ${CMAKE_SYSTEM_NAME}) if(${SG_SYSTEM_NAME} MATCHES "kFreeBSD") @@ -119,12 +132,6 @@ if(enable_lib_in_jar) COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_BINARY_DIR}/lib/${LIBSIMGRID_SO} ${JAVA_NATIVE_PATH} COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_BINARY_DIR}/lib/${LIBSIMGRID_JAVA_SO} ${JAVA_NATIVE_PATH} COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_BINARY_DIR}/lib/${LIBSURF_JAVA_SO} ${JAVA_NATIVE_PATH} - - # strip seems to fail on Mac on binaries that are already stripped. - # It then spits: "symbols referenced by indirect symbol table entries that can't be stripped" - COMMAND ${STRIP_COMMAND} ${JAVA_NATIVE_PATH}/${LIBSIMGRID_SO} || true - COMMAND ${STRIP_COMMAND} ${JAVA_NATIVE_PATH}/${LIBSIMGRID_JAVA_SO} || true - COMMAND ${STRIP_COMMAND} ${JAVA_NATIVE_PATH}/${LIBSURF_JAVA_SO} || true COMMAND ${JAVA_ARCHIVE} -uvf ${SIMGRID_JAR} NATIVE COMMAND ${CMAKE_COMMAND} -E remove_directory NATIVE @@ -154,7 +161,7 @@ endif(enable_lib_in_jar) include_directories(${JNI_INCLUDE_DIRS} ${JAVA_INCLUDE_PATH} ${JAVA_INCLUDE_PATH2}) -if(SWIG_FOUND) +if(${SWIG_FOUND}) set(CMAKE_SWIG_FLAGS "-package" "org.simgrid.surf") set(CMAKE_SWIG_OUTDIR "${CMAKE_HOME_DIRECTORY}/src/bindings/java/org/simgrid/surf")