X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FConfig%2FCMakeLists.txt;h=aa9136edc0493da581ef072a3d44bce5c1ef142c;hb=95ff1008bc8215fdeafd7d253dc5a6f33e949363;hp=75cb0970339c0fb765869c226ed77c7967a96ecd;hpb=fadb4e755f16bbc61879a926a689cf472bd4a76b;p=modules%2Fshaper.git diff --git a/src/Config/CMakeLists.txt b/src/Config/CMakeLists.txt index 75cb09703..aa9136edc 100644 --- a/src/Config/CMakeLists.txt +++ b/src/Config/CMakeLists.txt @@ -1,7 +1,27 @@ -## Copyright (C) 2014-20xx CEA/DEN, EDF R&D +# Copyright (C) 2014-2021 CEA/DEN, EDF R&D +# +# This library is free software; you can redistribute it and/or +# modify it under the terms of the GNU Lesser General Public +# License as published by the Free Software Foundation; either +# version 2.1 of the License, or (at your option) any later version. +# +# This library is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# Lesser General Public License for more details. +# +# You should have received a copy of the GNU Lesser General Public +# License along with this library; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +# +# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com +# INCLUDE(Common) +INCLUDE(UnitTest) INCLUDE(XMLProcessing) +FIND_PACKAGE(SWIG REQUIRED) +INCLUDE(${SWIG_USE_FILE}) INCLUDE_DIRECTORIES (${PROJECT_SOURCE_DIR}/src/Events ${PYTHON_INCLUDE_DIR}) @@ -9,6 +29,7 @@ INCLUDE_DIRECTORIES (${PROJECT_SOURCE_DIR}/src/Events SET(PROJECT_HEADERS Config_def.h Config_FeatureMessage.h + Config_PluginMessage.h Config_XMLReader.h Config_ModuleReader.h Config_FeatureReader.h @@ -21,13 +42,14 @@ SET(PROJECT_HEADERS Config_Prop.h Config_PropManager.h Config_AttributeMessage.h - Config_SelectionFilterMessage.h Config_ValidatorReader.h Config_DataModelReader.h + Config_Translator.h ) SET(PROJECT_SOURCES Config_FeatureMessage.cpp + Config_PluginMessage.cpp Config_XMLReader.cpp Config_ModuleReader.cpp Config_FeatureReader.cpp @@ -39,11 +61,32 @@ SET(PROJECT_SOURCES Config_Prop.cpp Config_PropManager.cpp Config_AttributeMessage.cpp - Config_SelectionFilterMessage.cpp Config_ValidatorReader.cpp Config_DataModelReader.cpp + Config_Translator.cpp ) +SET(CMAKE_SWIG_FLAGS -threads -w321,401) +SET_SOURCE_FILES_PROPERTIES(ConfigAPI.i PROPERTIES CPLUSPLUS ON) +SET_SOURCE_FILES_PROPERTIES(ConfigAPI.i PROPERTIES SWIG_DEFINITIONS "-shadow") +SET(SWIG_SCRIPTS + ${CMAKE_CURRENT_BINARY_DIR}/ConfigAPI.py +) +SET(SWIG_LINK_LIBRARIES + Config + ${PYTHON_LIBRARIES} +) +IF(${CMAKE_VERSION} VERSION_GREATER "3.8.0") + SWIG_ADD_LIBRARY(ConfigAPI LANGUAGE python SOURCES ConfigAPI.i ${PROJECT_HEADERS}) +ELSE() + SWIG_ADD_MODULE(ConfigAPI python ConfigAPI.i ${PROJECT_HEADERS}) +ENDIF() +SWIG_LINK_LIBRARIES(ConfigAPI ${SWIG_LINK_LIBRARIES}) +IF(WIN32) + SET_TARGET_PROPERTIES(_ConfigAPI PROPERTIES DEBUG_OUTPUT_NAME _ConfigAPI_d) +ENDIF(WIN32) + + SET(XML_RESOURCES ${CMAKE_CURRENT_BINARY_DIR}/plugins.xml dataModel.xml @@ -67,7 +110,7 @@ TARGET_LINK_LIBRARIES(Config ${PROJECT_LIBRARIES}) # Prepare plugins.xml # the solver to activate after installation -SET(DEFAULT_SOLVER "SolveSpace") +SET(DEFAULT_SOLVER "PlaneGCS") # the list of all solvers SET(SOLVERS "SolveSpace" "PlaneGCS") @@ -82,9 +125,9 @@ ENDFOREACH() # check default solver in the list of solvers LIST(FIND SOLVERS ${DEFAULT_SOLVER} INDEX) IF(${INDEX} GREATER -1) - MESSAGE(STATUS "Default solver: ${DEFAULT_SOLVER}") + MESSAGE(STATUS "Default solver: ${DEFAULT_SOLVER}") ELSE() - MESSAGE(FATAL_ERROR "Default solver: ${DEFAULT_SOLVER} is switched off.\nUnset NO_${DEFAULT_SOLVER} variable or define another default solver DEFAULT_SOLVER= from the list: ${SOLVERS}.") + MESSAGE(FATAL_ERROR "Default solver: ${DEFAULT_SOLVER} is switched off.\nUnset NO_${DEFAULT_SOLVER} variable or define another default solver DEFAULT_SOLVER= from the list: ${SOLVERS}.") ENDIF() # prepare variables for configuration @@ -102,5 +145,29 @@ CONFIGURE_FILE( "${CMAKE_CURRENT_BINARY_DIR}/plugins.xml" ) -INSTALL(TARGETS Config DESTINATION bin) -INSTALL(FILES ${XML_RESOURCES} DESTINATION plugins) +INSTALL(TARGETS Config DESTINATION ${SHAPER_INSTALL_BIN}) +INSTALL(FILES ${XML_RESOURCES} DESTINATION ${SHAPER_INSTALL_XML_RESOURCES}) + +INSTALL(TARGETS _ConfigAPI DESTINATION ${SHAPER_INSTALL_SWIG}) +INSTALL(FILES ${SWIG_SCRIPTS} DESTINATION ${SHAPER_INSTALL_SWIG}) + +include(tests.set) + +ADD_UNIT_TESTS(${TEST_NAMES}) + +if(${HAVE_SALOME}) + enable_testing() + set(TEST_INSTALL_DIRECTORY "${SALOME_SHAPER_INSTALL_TESTS}/Config") + + install(FILES CTestTestfileInstall.cmake + DESTINATION ${TEST_INSTALL_DIRECTORY} + RENAME CTestTestfile.cmake) + install(FILES tests.set DESTINATION ${TEST_INSTALL_DIRECTORY}) + + set(TMP_TESTS_NAMES) + foreach(tfile ${TEST_NAMES}) + list(APPEND TMP_TESTS_NAMES "Test/${tfile}") + endforeach(tfile ${TEST_NAMES}) + + install(FILES ${TMP_TESTS_NAMES} DESTINATION ${TEST_INSTALL_DIRECTORY}) +endif(${HAVE_SALOME})