X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/0f7698660d1ad8ab24d92e4c746d521de60e23be..919d53973306ca235d39729d640610f5dfbaa615:/buildtools/Cmake/src/CMakeMakeExeLib.txt diff --git a/buildtools/Cmake/src/CMakeMakeExeLib.txt b/buildtools/Cmake/src/CMakeMakeExeLib.txt index e5810ab266..accba92742 100644 --- a/buildtools/Cmake/src/CMakeMakeExeLib.txt +++ b/buildtools/Cmake/src/CMakeMakeExeLib.txt @@ -1,23 +1,26 @@ ### Make Libs -if(supernovae) +if(enable_supernovae) include(${PROJECT_DIRECTORY}/buildtools/Cmake/src/CMakeSupernovae.txt) -else(supernovae) +else(enable_supernovae) add_library(simgrid SHARED ${simgrid_sources}) add_library(simgrid_static STATIC ${simgrid_sources}) add_library(gras SHARED ${gras_sources}) - add_library(smpi STATIC ${SMPI_SRC}) -endif(supernovae) + add_library(smpi SHARED ${SMPI_SRC}) +endif(enable_supernovae) -set(GRAS_DEP "pthread") -set(SIMGRID_DEP "ruby1.8") +set_target_properties(simgrid PROPERTIES VERSION ${libsimgrid_version}) +set_target_properties(gras PROPERTIES VERSION ${libgras_version}) +set_target_properties(smpi PROPERTIES VERSION ${libsmpi_version}) + +set(GRAS_DEP "-lm -lpthread") +set(SIMGRID_DEP "-lm") set(SMPI_DEP "") -if(HAVE_RUBY_H) - add_library(simgrid_ruby STATIC ${PROJECT_DIRECTORY}/src/bindings/ruby/simgrid_ruby.c) - set(RUBY_DEP "-lm -module") - target_link_libraries(simgrid_ruby simgrid ${RUBY_DEP} -fprofile-arcs) -endif(HAVE_RUBY_H) +if(HAVE_RUBY) + set(SIMGRID_DEP "${SIMGRID_DEP} -l${libruby} -module") + exec_program("ln -sf ${PROJECT_DIRECTORY}/src/.libs/libsimgrid.so ${PROJECT_DIRECTORY}/src/bindings/ruby/libsimgrid.so" "${PROJECT_DIRECTORY}" OUTPUT_VARIABLE LIEN_OK) +endif(HAVE_RUBY) if(CMAKE_SYSTEM_NAME MATCHES "Darwin") add_definitions("-D_XOPEN_SOURCE") @@ -36,16 +39,17 @@ endif(pthread) if(HAVE_LUA) SET(SIMGRID_DEP "${SIMGRID_DEP} -ldl -l${liblua}") + exec_program("ln -sf ${PROJECT_DIRECTORY}/src/.libs/libsimgrid.so ${PROJECT_DIRECTORY}/examples/lua/simgrid.so" "${PROJECT_DIRECTORY}" OUTPUT_VARIABLE LIEN_OK) endif(HAVE_LUA) if(HAVE_GTNETS) SET(SIMGRID_DEP "${SIMGRID_DEP} -lgtnets") endif(HAVE_GTNETS) -if(NOT HAVE_RUBY_H) - string(REPLACE "ruby1.8 -l" "" SIMGRID_DEP ${SIMGRID_DEP}) - string(REPLACE "ruby1.8" "" SIMGRID_DEP ${SIMGRID_DEP}) -endif(NOT HAVE_RUBY_H) +if(HAVE_POSIX_GETTIME) + SET(SIMGRID_DEP "${SIMGRID_DEP} -lrt") + SET(GRAS_DEP "${GRAS_DEP} -lrt") +endif(HAVE_POSIX_GETTIME) target_link_libraries(simgrid ${SIMGRID_DEP} -fprofile-arcs) target_link_libraries(simgrid_static ${SIMGRID_DEP} -fprofile-arcs) @@ -58,7 +62,9 @@ target_link_libraries(smpi simgrid ${SMPI_DEP} -fprofile-arcs) ### Make EXEs -#tools +#src/testall +add_subdirectory(${PROJECT_DIRECTORY}/src) + #tools/gras add_subdirectory(${PROJECT_DIRECTORY}/tools/gras) @@ -110,6 +116,7 @@ add_subdirectory(${PROJECT_DIRECTORY}/examples/msg/parallel_task) add_subdirectory(${PROJECT_DIRECTORY}/examples/msg/priority) add_subdirectory(${PROJECT_DIRECTORY}/examples/msg/masterslave) add_subdirectory(${PROJECT_DIRECTORY}/examples/msg/trace) +add_subdirectory(${PROJECT_DIRECTORY}/examples/msg/tracing) if(HAVE_GTNETS) add_definitions("-lgtnets -L${gtnets_path}/lib -I${gtnets_path}/include/gtnets") add_subdirectory(${PROJECT_DIRECTORY}/examples/msg/gtnets) @@ -125,27 +132,118 @@ add_subdirectory(${PROJECT_DIRECTORY}/examples/simdag/properties) add_subdirectory(${PROJECT_DIRECTORY}/examples/smpi) if(HAVE_JAVA) - message("Make : src/simgrid.jar with : ${JAVA_COMPILE}") - exec_program("rm -rf ${PROJECT_DIRECTORY}/src/.classes" OUTPUT_VARIABLE "SIM_JAR_OK") - exec_program("rm ${PROJECT_DIRECTORY}/src/simgrid.jar" OUTPUT_VARIABLE "SIM_JAR_OK") - exec_program("mkdir ${PROJECT_DIRECTORY}/src/.classes" OUTPUT_VARIABLE "SIM_JAR_OK") foreach(file ${JMSG_JAVA_SRC}) - set(java_src_to_compile "${java_src_to_compile} ${file}") + set(java_src_to_compile "${java_src_to_compile}${file} ") endforeach(file ${JMSG_JAVA_SRC}) - #message("files java : ${java_src_to_compile}") - exec_program("${JAVA_COMPILE}" ARGS "-d ${PROJECT_DIRECTORY}/src/.classes -cp ${PROJECT_DIRECTORY}/src/.classes ${java_src_to_compile}" OUTPUT_VARIABLE "SIM_COMPILE_OK") - exec_program("mkdir ${PROJECT_DIRECTORY}/src/.classes/surf" OUTPUT_VARIABLE "SIM_JAR_OK") - exec_program("cp ${PROJECT_DIRECTORY}/src/surf/simgrid.dtd ${PROJECT_DIRECTORY}/src/.classes/surf/simgrid.dtd" OUTPUT_VARIABLE "SIM_JAR_OK") - exec_program("${JAVA_ARCHIVE}" ARGS "cvf ./src/simgrid.jar -C ${PROJECT_DIRECTORY}/src/.classes ." OUTPUT_VARIABLE "SIM_JAR_OK") - - message("Make examples/java with : ${JAVA_COMPILE}") - exec_program("rm ${PROJECT_DIRECTORY}/examples/java/basic/*.class" OUTPUT_VARIABLE "SIM_JAR_OK") - exec_program("${JAVA_COMPILE}" ARGS "-d ${PROJECT_DIRECTORY}/examples/java/basic -cp ${PROJECT_DIRECTORY}/src/simgrid.jar ${PROJECT_DIRECTORY}/examples/java/basic/*.java" OUTPUT_VARIABLE "SIM_JAR_OK") - exec_program("rm ${PROJECT_DIRECTORY}/examples/java/ping_pong/*.class" OUTPUT_VARIABLE "SIM_JAR_OK") - exec_program("${JAVA_COMPILE}" ARGS "-d ${PROJECT_DIRECTORY}/examples/java/ping_pong -cp ${PROJECT_DIRECTORY}/src/simgrid.jar ${PROJECT_DIRECTORY}/examples/java/ping_pong/*.java" OUTPUT_VARIABLE "SIM_JAR_OK") - exec_program("rm ${PROJECT_DIRECTORY}/examples/java/comm_time/*.class" OUTPUT_VARIABLE "SIM_JAR_OK") - exec_program("${JAVA_COMPILE}" ARGS "-d ${PROJECT_DIRECTORY}/examples/java/comm_time -cp ${PROJECT_DIRECTORY}/src/simgrid.jar ${PROJECT_DIRECTORY}/examples/java/comm_time/*.java" OUTPUT_VARIABLE "SIM_JAR_OK") - exec_program("rm ${PROJECT_DIRECTORY}/examples/java/suspend/*.class" OUTPUT_VARIABLE "SIM_JAR_OK") - exec_program("${JAVA_COMPILE}" ARGS "-d ${PROJECT_DIRECTORY}/examples/java/suspend -cp ${PROJECT_DIRECTORY}/src/simgrid.jar ${PROJECT_DIRECTORY}/examples/java/suspend/*.java" OUTPUT_VARIABLE "SIM_JAR_OK") + + string(REPLACE ".java" ".class" java_output "${JMSG_JAVA_SRC}") + +# message("\n\njava_src:\n${JMSG_JAVA_SRC}") +# message("\n\njava_src_to_compile:\n${java_src_to_compile}") +# message("\n\njava_output:\n${java_output}") + +file(REMOVE_RECURSE ${PROJECT_DIRECTORY}/src/.classes) +file(REMOVE ${PROJECT_DIRECTORY}/src/simgrid.jar) +file(MAKE_DIRECTORY ${PROJECT_DIRECTORY}/src/.classes) +file(MAKE_DIRECTORY ${PROJECT_DIRECTORY}/src/.classes/surf) +configure_file(${PROJECT_DIRECTORY}/src/surf/simgrid.dtd ${PROJECT_DIRECTORY}/src/.classes/surf/simgrid.dtd COPYONLY) + +# build .jar file from .class files +ADD_CUSTOM_TARGET(simgrid.jar ALL +COMMAND ${JAVA_COMPILE} -d ${PROJECT_DIRECTORY}/src/.classes -cp ${PROJECT_DIRECTORY}/src/.classes ${PROJECT_DIRECTORY}/src/java/simgrid/msg/*.java +) + +ADD_CUSTOM_COMMAND( +TARGET simgrid.jar +POST_BUILD +COMMAND ${CMAKE_COMMAND} +ARGS -E chdir ${PROJECT_DIRECTORY} +${JAVA_ARCHIVE} -cvf ${PROJECT_DIRECTORY}/src/simgrid.jar -C ${PROJECT_DIRECTORY}/src/.classes . +) + +ADD_CUSTOM_COMMAND( +TARGET simgrid.jar +POST_BUILD +COMMAND rm -f ${PROJECT_DIRECTORY}/examples/java/basic/*.class +COMMAND ${JAVA_COMPILE} +ARGS -d ${PROJECT_DIRECTORY}/examples/java/basic -cp ${PROJECT_DIRECTORY}/src/simgrid.jar +${PROJECT_DIRECTORY}/examples/java/basic/*.java +) + +ADD_CUSTOM_COMMAND( +TARGET simgrid.jar +POST_BUILD +COMMAND rm -f ${PROJECT_DIRECTORY}/examples/java/ping_pong/*.class +COMMAND ${JAVA_COMPILE} +ARGS -d ${PROJECT_DIRECTORY}/examples/java/ping_pong -cp ${PROJECT_DIRECTORY}/src/simgrid.jar +${PROJECT_DIRECTORY}/examples/java/ping_pong/*.java +) + +ADD_CUSTOM_COMMAND( +TARGET simgrid.jar +POST_BUILD +COMMAND rm -f ${PROJECT_DIRECTORY}/examples/java/comm_time/*.class +COMMAND ${JAVA_COMPILE} +ARGS -d ${PROJECT_DIRECTORY}/examples/java/comm_time -cp ${PROJECT_DIRECTORY}/src/simgrid.jar +${PROJECT_DIRECTORY}/examples/java/comm_time/*.java +) + +ADD_CUSTOM_COMMAND( +TARGET simgrid.jar +POST_BUILD +COMMAND rm -f ${PROJECT_DIRECTORY}/examples/java/suspend/*.class +COMMAND ${JAVA_COMPILE} +ARGS -d ${PROJECT_DIRECTORY}/examples/java/suspend -cp ${PROJECT_DIRECTORY}/src/simgrid.jar +${PROJECT_DIRECTORY}/examples/java/suspend/*.java +) endif(HAVE_JAVA) + +set(targets_depended_of_gras_stub_generator +ping_client +ping_server +ping_simulator +rpc_client +rpc_forwarder +rpc_server +rpc_simulator +spawn_child +spawn_father +spawn_simulator +timer_client +timer_simulator +chrono_multiplier +chrono_simulator +simple_token_node +simple_token_simulator +mmrpc_client +mmrpc_server +mmrpc_simulator +all2all_receiver +all2all_sender +all2all_simulator +pmm_master +pmm_simulator +pmm_slave +synchro_philosopher +synchro_simulator +properties_alice +properties_bob +properties_simulator +msg_handle_client +msg_handle_server +msg_handle_simulator +empty_main_function +empty_main_simulator +small_sleep_function +small_sleep_simulator +bandwidth_maestro +bandwidth_sensor +bandwidth_simulator +saturate_maestro +saturate_sensor +saturate_simulator +) +foreach(file ${targets_depended_of_gras_stub_generator}) + add_dependencies(${file} gras_stub_generator) +endforeach(file ${targets_depended_of_gras_stub_generator})