X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FConstructionAPI%2FCMakeLists.txt;h=3446bddeeb1b46f2aad9c51bf6047037bab8e164;hb=b0d599305446d6542baefbf4bb7bcf5ae2de4633;hp=8faa88b4397e00a79f203709380149d82dd7c949;hpb=228158eaa9e34abd76e648acf24305ade1377947;p=modules%2Fshaper.git diff --git a/src/ConstructionAPI/CMakeLists.txt b/src/ConstructionAPI/CMakeLists.txt index 8faa88b43..3446bddee 100644 --- a/src/ConstructionAPI/CMakeLists.txt +++ b/src/ConstructionAPI/CMakeLists.txt @@ -1,59 +1,90 @@ -## Copyright (C) 2014-20xx CEA/DEN, EDF R&D +# Copyright (C) 2014-2019 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) - -FIND_PACKAGE(SWIG REQUIRED) -INCLUDE(${SWIG_USE_FILE}) -INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}) - SET(PROJECT_HEADERS - ConstructionAPI.h - ConstructionAPI_Point.h - ) + ConstructionAPI.h + ConstructionAPI_Axis.h + ConstructionAPI_Plane.h + ConstructionAPI_Point.h +) SET(PROJECT_SOURCES - ConstructionAPI_Point.cpp - ) + ConstructionAPI_Axis.cpp + ConstructionAPI_Plane.cpp + ConstructionAPI_Point.cpp +) SET(PROJECT_LIBRARIES - ModelAPI - ModelHighAPI - ) + ModelAPI + ModelHighAPI +) + +INCLUDE_DIRECTORIES( + ${PROJECT_SOURCE_DIR}/src/Events + ${PROJECT_SOURCE_DIR}/src/ModelAPI + ${PROJECT_SOURCE_DIR}/src/ModelHighAPI +) -ADD_DEFINITIONS(-DCONSTRUCTIONAPI_EXPORTS ${CAS_DEFINITIONS}) +# Plugin headers dependency +INCLUDE_DIRECTORIES( + # TODO(spo): modify ConstructionPlugin headers to remove dependency on GeomAPI headers + ${PROJECT_SOURCE_DIR}/src/GeomAPI + # TODO(spo): it is for *_swig.h files. Can we eliminate it? + ${PROJECT_SOURCE_DIR}/src/GeomDataAPI + ${PROJECT_SOURCE_DIR}/src/ConstructionPlugin +) + +#TODO(spo): is ${OpenCASCADE_DEFINITIONS} necessary? +ADD_DEFINITIONS(-DCONSTRUCTIONAPI_EXPORTS ${OpenCASCADE_DEFINITIONS}) ADD_LIBRARY(ConstructionAPI SHARED ${PROJECT_SOURCES} ${PROJECT_HEADERS}) +TARGET_LINK_LIBRARIES(ConstructionAPI ${PROJECT_LIBRARIES}) + +# SWIG wrapper -SET(CMAKE_SWIG_FLAGS "-Wall") +INCLUDE(PythonAPI) SET_SOURCE_FILES_PROPERTIES(ConstructionAPI.i PROPERTIES CPLUSPLUS ON) SET_SOURCE_FILES_PROPERTIES(ConstructionAPI.i PROPERTIES SWIG_DEFINITIONS "-shadow") -INCLUDE_DIRECTORIES( - ${PROJECT_SOURCE_DIR}/src/ModelAPI - ${PROJECT_SOURCE_DIR}/src/ModelHighAPI - ) - -TARGET_LINK_LIBRARIES(ConstructionAPI ${PROJECT_LIBRARIES}) - -SET(SWIG_SCRIPTS - ${CMAKE_CURRENT_BINARY_DIR}/ConstructionAPI.py - ) - +#TODO(spo): is ModelAPI necessary or it could be received by INTERFACE_ (may require modern CMake)? SET(SWIG_LINK_LIBRARIES - ConstructionAPI - ModelHighAPI - ModelAPI - ${PYTHON_LIBRARIES} - ) + ConstructionAPI + ModelHighAPI + ModelAPI + ${PYTHON_LIBRARIES} +) -SET(SWIG_MODULE_ConstructionAPI_EXTRA_DEPS ${SWIG_MODULE_ConstructionAPI_EXTRA_DEPS} - ${PROJECT_SOURCE_DIR}/src/ModelHighAPI/ModelHighAPI.i - ${PROJECT_HEADERS} - ) +SET(CMAKE_SWIG_FLAGS -threads -w325,321,302,362,322,383,403) -SWIG_ADD_MODULE(ConstructionAPI python ConstructionAPI.i ${PROJECT_HEADERS}) +SET(SWIG_MODULE_ConstructionAPI_EXTRA_DEPS ${SWIG_MODULE_ConstructionAPI_EXTRA_DEPS} + ${PROJECT_SOURCE_DIR}/src/ModelHighAPI/ModelHighAPI.i + doxyhelp.i + ${PROJECT_HEADERS} +) + +IF(${CMAKE_VERSION} VERSION_GREATER "3.8.0") + SWIG_ADD_LIBRARY(ConstructionAPI LANGUAGE python SOURCES ConstructionAPI.i ${PROJECT_HEADERS}) +ELSE() + SWIG_ADD_MODULE(ConstructionAPI python ConstructionAPI.i ${PROJECT_HEADERS}) +ENDIF() SWIG_LINK_LIBRARIES(ConstructionAPI ${SWIG_LINK_LIBRARIES}) IF(WIN32) @@ -62,10 +93,13 @@ ENDIF(WIN32) INSTALL(TARGETS _ConstructionAPI DESTINATION ${SHAPER_INSTALL_SWIG}) INSTALL(TARGETS ConstructionAPI DESTINATION ${SHAPER_INSTALL_BIN}) -INSTALL(FILES ${SWIG_SCRIPTS} DESTINATION ${SHAPER_INSTALL_SWIG}) +INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/ConstructionAPI.py DESTINATION ${SHAPER_INSTALL_SWIG}) -ADD_UNIT_TESTS( - TestPoint.py - ) +# Tests + +INCLUDE(UnitTest) -ADD_SUBDIRECTORY (Test) +ADD_UNIT_TESTS( + TestPoint.py + TestAxis.py +)