X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/ffe8ce65fd9a8e18a0469f26f067c3ea6d5d60d4..3f39df9e2a9e798f07a880c9a03ec8fe20dabe79:/buildtools/Cmake/MakeLib.cmake diff --git a/buildtools/Cmake/MakeLib.cmake b/buildtools/Cmake/MakeLib.cmake index 91611c92c0..2f46f6d2ac 100644 --- a/buildtools/Cmake/MakeLib.cmake +++ b/buildtools/Cmake/MakeLib.cmake @@ -33,20 +33,34 @@ endif() # Compute the dependencies of SimGrid ##################################### set(SIMGRID_DEP "-lm") +if (HAVE_BOOST_CONTEXT) + set(SIMGRID_DEP "${SIMGRID_DEP} ${Boost_CONTEXT_LIBRARY}") +endif() if(${CMAKE_SYSTEM_NAME} STREQUAL "FreeBSD" AND NOT ${CMAKE_SYSTEM_VERSION} VERSION_LESS 10.0 AND ${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang") # FreeBSD from 10.0 provide a internal C++ stack (unused by gcc) + # see https://wiki.freebsd.org/NewC%2B%2BStack set(SIMGRID_DEP "${SIMGRID_DEP} -lc++") +elseif(${CMAKE_SYSTEM_NAME} STREQUAL "FreeBSD" + AND ${CMAKE_SYSTEM_VERSION} VERSION_LESS 10.0 + AND ${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang") + # FreeBSD prior to 10.0 does not necessarily have a compiler + # installed that is capable of c++11! Hence, we just assume + # here that libc++ was compiled. + # FIXME: We should change this behavior; we may want to include + # an option of whether libc++ (clang++) or libstdc++ (g++) + # should be used. + include_directories( "/usr/local/include/c++/v1") + set(SIMGRID_DEP "${SIMGRID_DEP} -lc++ -L/usr/local/lib ") else() set(SIMGRID_DEP "${SIMGRID_DEP} -lstdc++") endif() -if(pthread) - if(${CONTEXT_THREADS}) - SET(SIMGRID_DEP "${SIMGRID_DEP} -pthread") - endif() +if(pthread AND ${CONTEXT_THREADS} AND NOT APPLE) + # Clang on recent Mac OS X is not happy about -pthread. + SET(SIMGRID_DEP "${SIMGRID_DEP} -pthread") endif() if(HAVE_LUA) @@ -86,21 +100,17 @@ if(HAVE_GRAPHVIZ) endif() if(HAVE_LIBSIGC++) - SET(SIMGRID_DEP "${SIMGRID_DEP} -lsigc-2.0") + SET(SIMGRID_DEP "${SIMGRID_DEP} -lsigc-2.0") endif() if(HAVE_GTNETS) SET(SIMGRID_DEP "${SIMGRID_DEP} -lgtnets") endif() -if(enable_mc_content_adressable_pages) - SET(SIMGRID_DEP "${SIMGRID_DEP} -lnettle") -endif() - if(HAVE_MC) # The availability of libunwind was checked in CompleteInFiles.cmake # (that includes FindLibunwind.cmake), so simply load it now. - + SET(SIMGRID_DEP "${SIMGRID_DEP} -lunwind -lunwind-ptrace") # Same for libdw @@ -109,7 +119,7 @@ if(HAVE_MC) # This is deeply wrong, and should be fixed by manually loading -lunwind-PLAT (FIXME) if(PROCESSOR_x86_64) SET(SIMGRID_DEP "${SIMGRID_DEP} -lunwind-x86_64") - else() + else() SET(SIMGRID_DEP "${SIMGRID_DEP} -lunwind-x86") endif() endif() @@ -119,13 +129,7 @@ if(MMALLOC_WANT_OVERRIDE_LEGACY AND HAVE_GNU_LD) endif() if(HAVE_NS3) - if(${NS3_VERSION_MINOR} EQUAL 10) - SET(SIMGRID_DEP "${SIMGRID_DEP} -lns3") - set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -D_NS3_3_10") - set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -D_NS3_3_10") - else() - SET(SIMGRID_DEP "${SIMGRID_DEP} -lns3.${NS3_VERSION_MINOR}-core -lns3.${NS3_VERSION_MINOR}-csma -lns3.${NS3_VERSION_MINOR}-point-to-point -lns3.${NS3_VERSION_MINOR}-internet -lns3.${NS3_VERSION_MINOR}-applications") - endif() + SET(SIMGRID_DEP "${SIMGRID_DEP} -lns${NS3_VERSION}-core -lns${NS3_VERSION}-csma -lns${NS3_VERSION}-point-to-point -lns${NS3_VERSION}-internet -lns${NS3_VERSION}-applications") endif() if(HAVE_POSIX_GETTIME)