X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/cc83f5e22fe421207bc2768c4136a1d62d6f7352..13ea2aa105a0670ea63ce4bc8f08fb3a884e2e73:/buildtools/Cmake/MakeLib.cmake diff --git a/buildtools/Cmake/MakeLib.cmake b/buildtools/Cmake/MakeLib.cmake index 5a477cc5ff..6125097507 100644 --- a/buildtools/Cmake/MakeLib.cmake +++ b/buildtools/Cmake/MakeLib.cmake @@ -47,11 +47,49 @@ if(enable_java) endif() set(CMAKE_JAVA_TARGET_OUTPUT_NAME simgrid) - set(MANIFEST_FILE ${CMAKE_HOME_DIRECTORY}/src/bindings/java/MANIFEST.MF) add_jar(SG_java_jar ${JMSG_JAVA_SRC}) - add_custom_command(TARGET SG_java_jar POST_BUILD - DEPENDS ${MANIFEST_FILE} - COMMAND ${JAVA_ARCHIVE} -uvmf ${MANIFEST_FILE} ${CMAKE_BINARY_DIR}/${CMAKE_JAVA_TARGET_OUTPUT_NAME}.jar) + + set(SIMGRID_JAR "${CMAKE_BINARY_DIR}/simgrid.jar") + set(MANIFEST_FILE "${CMAKE_HOME_DIRECTORY}/src/bindings/java/MANIFEST.MF") + + if(CMAKE_SYSTEM_PROCESSOR MATCHES ".86") + if(${ARCH_32_BITS}) + set(JSG_BUNDLE "NATIVE/${CMAKE_SYSTEM_NAME}/x86/") + else() + set(JSG_BUNDLE "NATIVE/${CMAKE_SYSTEM_NAME}/amd64/") + endif() + else() + error("Unknown system type. Processor: ${CMAKE_SYSTEM_PROCESSOR}; System: ${CMAKE_SYSTEM_NAME}") + endif() + message("Native libraries bundled into: ${JSG_BUNDLE}") + + set(LIBSIMGRID_SO + ${CMAKE_SHARED_LIBRARY_PREFIX}simgrid${CMAKE_SHARED_LIBRARY_SUFFIX}) + set(LIBSG_JAVA_SO + ${CMAKE_SHARED_LIBRARY_PREFIX}simgrid${CMAKE_SHARED_LIBRARY_SUFFIX}) + + add_custom_command( + COMMENT "Finalize simgrid.jar..." + OUTPUT ${SIMGRID_JAR}_finalized + DEPENDS simgrid SG_java ${SIMGRID_JAR} ${MANIFEST_FILE} + ${CMAKE_HOME_DIRECTORY}/COPYING + ${CMAKE_HOME_DIRECTORY}/ChangeLog + ${CMAKE_HOME_DIRECTORY}/ChangeLog.SimGrid-java + WORKING_DIRECTORY "${CMAKE_BINARY_DIR}" + COMMAND ${CMAKE_COMMAND} -E remove_directory "NATIVE" + COMMAND ${CMAKE_COMMAND} -E make_directory "${JSG_BUNDLE}" + COMMAND ${CMAKE_COMMAND} -E copy "./lib/${LIBSIMGRID_SO}" "${JSG_BUNDLE}" + COMMAND ${CMAKE_STRIP} -S "${JSG_BUNDLE}/${LIBSIMGRID_SO}" + COMMAND ${CMAKE_COMMAND} -E copy "./lib/${LIBSG_JAVA_SO}" "${JSG_BUNDLE}" + COMMAND ${CMAKE_STRIP} -S "${JSG_BUNDLE}/${LIBSG_JAVA_SO}" + COMMAND ${CMAKE_COMMAND} -E copy "${CMAKE_HOME_DIRECTORY}/COPYING" "${JSG_BUNDLE}" + COMMAND ${CMAKE_COMMAND} -E copy "${CMAKE_HOME_DIRECTORY}/ChangeLog" "${JSG_BUNDLE}" + COMMAND ${CMAKE_COMMAND} -E copy "${CMAKE_HOME_DIRECTORY}/ChangeLog.SimGrid-java" "${JSG_BUNDLE}" + COMMAND ${JAVA_ARCHIVE} -uvmf ${MANIFEST_FILE} ${SIMGRID_JAR} "NATIVE" + COMMAND ${CMAKE_COMMAND} -E touch ${SIMGRID_JAR}_finalized + ) + add_custom_target(SG_java_jar_finalize DEPENDS ${SIMGRID_JAR}_finalized) + add_dependencies(SG_java_jar SG_java_jar_finalize) endif() add_dependencies(simgrid maintainer_files)