X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=CMakeLists.txt;h=561697239a975485863f04c2e8cd79cb191a7411;hb=5bae7bad273c0f11d32e127740bb9582396f99cf;hp=223001654d8af64d32e6ca78337d7cd769ad1fec;hpb=c1bc28d34120d2206f9db487718630c3da7acde7;p=modules%2Fshaper.git diff --git a/CMakeLists.txt b/CMakeLists.txt index 223001654..561697239 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,44 +1,117 @@ CMAKE_MINIMUM_REQUIRED(VERSION 2.8.10) -PROJECT (NewGEOM) +PROJECT (SHAPER) +SET (SHAPER_Version 2.5.0) SET(CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/CMakeCommon" ${CMAKE_MODULE_PATH}) +INCLUDE(FindEclipse) INCLUDE(Common) INCLUDE(FindQt) -INCLUDE(FindBoost) INCLUDE(FindPython) INCLUDE(FindSalome) +INCLUDE(FindCAS) +INCLUDE(FindSUIT) +INCLUDE(FindDFBrowser) +INCLUDE(FindVInspector) -IF(UNIX) - IF(CMAKE_COMPILER_IS_GNUCC) - SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++0x") - MESSAGE(STATUS "Setting -std=c++0x flag for the gcc...") - MESSAGE(STATUS "Now gcc flags are: " ${CMAKE_CXX_FLAGS}) - - ENDIF(CMAKE_COMPILER_IS_GNUCC) -ENDIF(UNIX) +# Find LibXml2 +IF(DEFINED ENV{LIBXML2_ROOT_DIR}) + IF(WIN32) + FILE(TO_CMAKE_PATH $ENV{LIBXML2_ROOT_DIR}/lib/libxml2.lib LIBXML2_LIBRARIES) + FILE(TO_CMAKE_PATH $ENV{LIBXML2_ROOT_DIR}/include LIBXML2_INCLUDE_DIR) + ELSE() + FILE(TO_CMAKE_PATH $ENV{LIBXML2_ROOT_DIR}/lib/libxml2.so LIBXML2_LIBRARIES) + FILE(TO_CMAKE_PATH $ENV{LIBXML2_ROOT_DIR}/include/libxml2 LIBXML2_INCLUDE_DIR) + ENDIF() +ENDIF() +# It could be called only once +FIND_PACKAGE(LibXml2 REQUIRED) +IF(${HAVE_SALOME}) + SET(SHAPER_INSTALL_ADDONS bin/salome CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_BIN lib/salome CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_PLUGIN_FILES lib/salome CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_PYTHON_API bin/salome CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_PYTHON_FILES bin/salome CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_RESOURCES share/salome/resources/shaper CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_SWIG bin/salome CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_QM_RESOURCES share/salome/resources/shaper CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_XML_RESOURCES share/salome/resources/shaper CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_GUI_DOC share/doc/salome/gui/SHAPER CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_TUI_DOC share/doc/salome/tui/SHAPER CACHE INTERNAL "" FORCE) + # without SALOME there is another kind of documentation, separated one + ADD_SUBDIRECTORY (doc) +ELSE(${HAVE_SALOME}) + SET(SHAPER_INSTALL_ADDONS addons CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_BIN bin CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_PLUGIN_FILES plugins CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_PYTHON_API PythonAPI CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_PYTHON_FILES plugins CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_RESOURCES resources CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_SWIG swig CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_QM_RESOURCES bin CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_XML_RESOURCES plugins CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_GUI_DOC doc CACHE INTERNAL "" FORCE) + SET(SHAPER_INSTALL_TUI_DOC doc CACHE INTERNAL "" FORCE) +ENDIF(${HAVE_SALOME}) ADD_SUBDIRECTORY (src/Config) ADD_SUBDIRECTORY (src/Events) ADD_SUBDIRECTORY (src/Model) -ADD_SUBDIRECTORY (src/ModelAPI) +ADD_SUBDIRECTORY (src/XAO) ADD_SUBDIRECTORY (src/GeomAPI) +ADD_SUBDIRECTORY (src/ModelAPI) +ADD_SUBDIRECTORY (src/ModelGeomAlgo) ADD_SUBDIRECTORY (src/GeomAlgoAPI) +ADD_SUBDIRECTORY (src/GeomAlgoImpl) ADD_SUBDIRECTORY (src/GeomData) ADD_SUBDIRECTORY (src/GeomDataAPI) ADD_SUBDIRECTORY (src/PartSetPlugin) ADD_SUBDIRECTORY (src/ConstructionPlugin) +ADD_SUBDIRECTORY (src/BuildPlugin) +ADD_SUBDIRECTORY (src/PrimitivesPlugin) +ADD_SUBDIRECTORY (src/FeaturesPlugin) +ADD_SUBDIRECTORY (src/CollectionPlugin) +ADD_SUBDIRECTORY (src/SamplePanelPlugin) +ADD_SUBDIRECTORY (src/SketcherPrs) ADD_SUBDIRECTORY (src/SketchPlugin) +ADD_SUBDIRECTORY (src/SketchSolver) ADD_SUBDIRECTORY (src/ModuleBase) ADD_SUBDIRECTORY (src/PartSet) -ADD_SUBDIRECTORY (src/PyConsole) -ADD_SUBDIRECTORY (src/PyEvent) -ADD_SUBDIRECTORY (src/PyInterp) + ADD_SUBDIRECTORY (src/XGUI) -ADD_SUBDIRECTORY (src/GeomApp) +ADD_SUBDIRECTORY (src/ExchangePlugin) +ADD_SUBDIRECTORY (src/GeomValidators) +ADD_SUBDIRECTORY (src/InitializationPlugin) +ADD_SUBDIRECTORY (src/ParametersPlugin) +ADD_SUBDIRECTORY (src/PythonAddons) +ADD_SUBDIRECTORY (src/PythonAPI) +# High Level C++/Python API +ADD_SUBDIRECTORY (src/ModelHighAPI) +ADD_SUBDIRECTORY (src/BuildAPI) +ADD_SUBDIRECTORY (src/ConnectorAPI) +ADD_SUBDIRECTORY (src/ConstructionAPI) +ADD_SUBDIRECTORY (src/ExchangeAPI) +ADD_SUBDIRECTORY (src/FeaturesAPI) +ADD_SUBDIRECTORY (src/CollectionAPI) +ADD_SUBDIRECTORY (src/ParametersAPI) +ADD_SUBDIRECTORY (src/PartSetAPI) +ADD_SUBDIRECTORY (src/PrimitivesAPI) +ADD_SUBDIRECTORY (src/SketchAPI) IF(${HAVE_SALOME}) - ADD_SUBDIRECTORY (src/NewGeom) + ADD_SUBDIRECTORY (src/SHAPERGUI) + ADD_SUBDIRECTORY (src/ConnectorPlugin) ENDIF(${HAVE_SALOME}) + +ENABLE_TESTING() + +# Add the uninstall target for eclipse IDE +if (CMAKE_GENERATOR MATCHES "NMake Makefiles") +configure_file("${CMAKE_SOURCE_DIR}/CMakeCommon/cmake_uninstall.cmake.in" + "${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake" + IMMEDIATE @ONLY) +add_custom_target(uninstall + COMMAND ${CMAKE_COMMAND} -P ${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake) +endif (CMAKE_GENERATOR MATCHES "NMake Makefiles")