X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=CMakeLists.txt;h=561697239a975485863f04c2e8cd79cb191a7411;hb=5bae7bad273c0f11d32e127740bb9582396f99cf;hp=5639cfb13f32f8caafa0218bc577a5eb96d3976c;hpb=200f77f7819b363ecafeebbdec21dc6d1d0f8e0b;p=modules%2Fshaper.git diff --git a/CMakeLists.txt b/CMakeLists.txt index 5639cfb13..561697239 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,21 +1,117 @@ -CMAKE_MINIMUM_REQUIRED(VERSION 2.8.11) +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(FindPython) +INCLUDE(FindSalome) +INCLUDE(FindCAS) +INCLUDE(FindSUIT) +INCLUDE(FindDFBrowser) +INCLUDE(FindVInspector) + +# 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/Event) +ADD_SUBDIRECTORY (src/Events) ADD_SUBDIRECTORY (src/Model) +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/PartSetPlugin) -ADD_SUBDIRECTORY (src/PyConsole) -ADD_SUBDIRECTORY (src/PyEvent) -ADD_SUBDIRECTORY (src/PyInterp) + ADD_SUBDIRECTORY (src/XGUI) +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/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")