Salome HOME
updated copyright message
[modules/kernel.git] / src / DSC / DSC_Python / CMakeLists.txt
old mode 100755 (executable)
new mode 100644 (file)
index 2b83e19..5bad881
@@ -1,9 +1,9 @@
-# Copyright (C) 2012  CEA/DEN, EDF R&D
+# Copyright (C) 2012-2023  CEA, EDF, OPEN CASCADE
 #
 # 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.
+# 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
 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
 #
 
-FIND_PACKAGE(SWIG REQUIRED)
 INCLUDE(${SWIG_USE_FILE})
 
 SET_SOURCE_FILES_PROPERTIES(calcium.i PROPERTIES CPLUSPLUS ON)
+SET_SOURCE_FILES_PROPERTIES(calcium.i PROPERTIES SWIG_FLAGS "-py3")
 SET(CMAKE_SWIG_FLAGS "-noexcept")
-SET_SOURCE_FILES_PROPERTIES(calciumPYTHON_wrap.cxx PROPERTIES COMPILE_FLAGS "${OMNIORB_DEFINITIONS} ${BOOST_DEFINITIONS}")
+ADD_DEFINITIONS(${OMNIORB_DEFINITIONS} ${BOOST_DEFINITIONS} ${PYTHON_DEFINITIONS} ${NUMPY_DEFINITIONS})
 
 INCLUDE_DIRECTORIES(
-  ${OMNIORB_INCLUDE_DIRS}
+  ${OMNIORB_INCLUDE_DIR}
   ${PYTHON_INCLUDE_DIRS}
-  ${BOOST_INCLUDE_DIRS}
-  ${CMAKE_BINARY_DIR}/salome_adm
-  ${CMAKE_SOURCE_DIR}/src/DSC/DSC_User
-  ${CMAKE_SOURCE_DIR}/src/DSC/DSC_User/Datastream
-  ${CMAKE_SOURCE_DIR}/src/DSC/DSC_User/Datastream/Palm
-  ${CMAKE_SOURCE_DIR}/src/DSC/DSC_User/Datastream/Calcium
-  ${CMAKE_BINARY_DIR}/src/DSC/DSC_User/Datastream/Calcium
-  ${CMAKE_SOURCE_DIR}/src/DSC/DSC_User/Basic
-  ${CMAKE_SOURCE_DIR}/src/DSC/DSC_Basic
-  ${CMAKE_SOURCE_DIR}/src/SALOMELocalTrace
-  ${CMAKE_SOURCE_DIR}/src/Basics
-  ${CMAKE_SOURCE_DIR}/src/Utils
-  ${CMAKE_SOURCE_DIR}/src/Container
-  ${CMAKE_SOURCE_DIR}/src/GenericObj
-  ${CMAKE_SOURCE_DIR}/src/Notification
-  ${CMAKE_BINARY_DIR}/idl
+  ${NUMPY_INCLUDE_DIR}
+  ${PTHREAD_INCLUDE_DIR}
+  ${Boost_INCLUDE_DIRS}
+  ${OMNIORBPY_INCLUDE_DIR}
+  ${PROJECT_BINARY_DIR}/salome_adm
+  ${PROJECT_SOURCE_DIR}/src/DSC/DSC_User
+  ${PROJECT_SOURCE_DIR}/src/DSC/DSC_User/Datastream
+  ${PROJECT_SOURCE_DIR}/src/DSC/DSC_User/Datastream/Palm
+  ${PROJECT_SOURCE_DIR}/src/DSC/DSC_User/Datastream/Calcium
+  ${PROJECT_BINARY_DIR}/src/DSC/DSC_User/Datastream/Calcium
+  ${PROJECT_SOURCE_DIR}/src/DSC/DSC_User/Basic
+  ${PROJECT_SOURCE_DIR}/src/DSC/DSC_Basic
+  ${PROJECT_SOURCE_DIR}/src/SALOMELocalTrace
+  ${PROJECT_SOURCE_DIR}/src/Basics
+  ${PROJECT_SOURCE_DIR}/src/Utils
+  ${PROJECT_SOURCE_DIR}/src/Container
+  ${PROJECT_SOURCE_DIR}/src/GenericObj
+  ${PROJECT_SOURCE_DIR}/src/Notification
+  ${PROJECT_BINARY_DIR}/idl
   )
 
 SET(_calcium_LIBS
@@ -52,16 +55,20 @@ SET(_calcium_LIBS
   SalomeDSCSuperv
   SalomeDSCContainer
   SalomeContainer
-  ${CORBA_LIBS}
+  ${OMNIORB_LIBRARIES}
 )
 
-SWIG_ADD_MODULE(calcium python calcium.i)
+IF(${CMAKE_VERSION} VERSION_LESS "3.8.0") 
+  SWIG_ADD_MODULE(calcium python calcium.i)
+ELSE()
+  SWIG_ADD_LIBRARY(calcium LANGUAGE python SOURCES calcium.i)
+ENDIF()
+
 SWIG_LINK_LIBRARIES(calcium ${_calcium_LIBS})
-SET_TARGET_PROPERTIES(_calcium PROPERTIES COMPILE_FLAGS "${OMNIORB_DEFINITIONS} ${BOOST_DEFINITIONS}")
-INSTALL(TARGETS _calcium DESTINATION ${KERNEL_salomepythondir})
+INSTALL(TARGETS _calcium DESTINATION ${SALOME_INSTALL_PYTHON})
 
 SET(SCRIPTS
   dsccalcium.py
+  ${CMAKE_CURRENT_BINARY_DIR}/calcium.py
 )
-SALOME_INSTALL_SCRIPTS( ${SCRIPTS} ${KERNEL_salomepythondir})
-INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/calcium.py DESTINATION ${KERNEL_salomepythondir})
+SALOME_INSTALL_SCRIPTS( "${SCRIPTS}" ${SALOME_INSTALL_PYTHON} EXTRA_DPYS "${SWIG_MODULE_calcium_REAL_NAME}")