Salome HOME
[bos #26726] EDF 24466 - CheckAndImprove generates wrong result. Fix SIGSEGV on Check...
[modules/geom.git] / SalomeGEOMConfig.cmake.in
index d09e54767ddd4b3ef54c2a5267d06f7e2597c143..3586123d9a012ed32c03ceeb2f8ffd62645ada8c 100644 (file)
@@ -1,32 +1,27 @@
-# - Config file for the @PROJECT_NAME@ package
-# It defines the following variables. 
-# Specific to the pacakge @PROJECT_NAME@ itself:
-#  @PROJECT_NAME_UC@_ROOT_DIR_EXP - the root path of the installation providing this CMake file
+# Copyright (C) 2013-2021  CEA/DEN, EDF R&D, OPEN CASCADE
 #
-
-###############################################################
-#  Copyright (C) 2007-2013  CEA/DEN, EDF R&D, 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, or (at your option) any later version.
 #
-#  Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
-#  CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
+# 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.
 #
-#  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.
+# 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
 #
-#  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.
+# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
 #
-#  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
+
+# - Config file for the @PROJECT_NAME@ package
+# It defines the following variables. 
+# Specific to the package @PROJECT_NAME@ itself:
+#  @PROJECT_NAME_UC@_ROOT_DIR_EXP - the root path of the installation providing this CMake file
 #
-#  See http://www.salome-platform.org/ or
-#  email : webmaster.salome@opencascade.com
-###############################################################
 
 ### Initialisation performed by CONFIGURE_PACKAGE_CONFIG_FILE:
 @PACKAGE_INIT@
@@ -46,6 +41,9 @@ SET_AND_CHECK(GEOM_INCLUDE_DIRS "${GEOM_ROOT_DIR_EXP}/@SALOME_INSTALL_HEADERS@")
 SET(GEOM_INCLUDE_DIRS "${GEOM_INCLUDE_DIRS};@_SalomeGEOM_EXTRA_HEADERS@")
 SET(GEOM_DEFINITIONS "@KERNEL_DEFINITIONS@")
 
+# Package specific environment variables
+@_SalomeGEOM_EXTRA_ENV_FULL@
+
 #### Now the specificities
 
 # Options exported by the package:
@@ -55,14 +53,14 @@ SET(SALOME_GEOM_BUILD_TESTS  @SALOME_BUILD_TESTS@)
 # Advanced options
 SET(SALOME_GEOM_BUILD_GUI  @SALOME_BUILD_GUI@)
 SET(SALOME_GEOM_USE_OPENCV @SALOME_GEOM_USE_OPENCV@)
+SET(SALOME_GEOM_USE_VTK @SALOME_GEOM_USE_VTK@)
 
 # Level 1 prerequisites:
 SET_AND_CHECK(KERNEL_ROOT_DIR_EXP "@PACKAGE_KERNEL_ROOT_DIR@")
-SET_AND_CHECK(CAS_ROOT_DIR_EXP "@PACKAGE_CAS_ROOT_DIR@")
-SET_AND_CHECK(VTK_ROOT_DIR_EXP "@PACKAGE_VTK_ROOT_DIR@")
+SET_AND_CHECK(OPENCASCADE_ROOT_DIR_EXP "@PACKAGE_OPENCASCADE_ROOT_DIR@")
 
 # Optional level 1 prerequisites:
-IF(SALOME_BUILD_GUI)
+IF(SALOME_GEOM_BUILD_GUI)
   SET_AND_CHECK(GUI_ROOT_DIR_EXP "@PACKAGE_GUI_ROOT_DIR@")
   LIST(APPEND GEOM_DEFINITIONS   "@GUI_DEFINITIONS@")
 ENDIF()
@@ -70,26 +68,42 @@ IF(SALOME_GEOM_USE_OPENCV)
   SET_AND_CHECK(OPENCV_ROOT_DIR_EXP "@PACKAGE_OPENCV_ROOT_DIR@")
   LIST(APPEND GEOM_DEFINITIONS "-DWITH_OPENCV")
 ENDIF()
+IF(SALOME_GEOM_USE_VTK)
+  SET_AND_CHECK(VTK_ROOT_DIR_EXP "@PACKAGE_VTK_ROOT_DIR@")
+  LIST(APPEND GEOM_DEFINITIONS "-DWITH_VTK")
+ENDIF()
 
-# For all prerequisites, load the corresponding targets if the package was used 
+# For all prerequisites, load the corresponding targets if the package was used
 # in CONFIG mode. This ensures dependent projects link correctly
 # without having to set LD_LIBRARY_PATH:
-
-SET(_PREREQ OpenCV CAS VTK)
-SET(_PREREQ_CONFIG_DIR "@OpenCV_DIR@" "@CAS_DIR@" "@VTK_DIR@")
-LIST(LENGTH _PREREQ_CONFIG_DIR _list_len)
-# Another CMake stupidity - FOREACH(... RANGE r) generates r+1 numbers ...
-MATH(EXPR _range "${_list_len}-1")
-FOREACH(_p RANGE ${_range})
-  LIST(GET _PREREQ            ${_p} _pkg    )
-  LIST(GET _PREREQ_CONFIG_DIR ${_p} _pkg_dir)
-  IF(_pkg_dir)
-     MESSAGE(STATUS "===> Reloading targets from ${_pkg} ...")
-     FIND_PACKAGE(${_pkg} REQUIRED NO_MODULE 
-          PATHS "${_pkg_dir}" 
-          NO_DEFAULT_PATH)
-  ENDIF()
-ENDFOREACH()
+SET(_PREREQ_@PROJECT_NAME@ @_PREREQ_LIST@)
+SET(_PREREQ_@PROJECT_NAME@_CONFIG_DIR @_PREREQ_DIR_LIST@)
+SET(_PREREQ_@PROJECT_NAME@_COMPONENTS "@_PREREQ_COMPO_LIST@")
+LIST(LENGTH _PREREQ_@PROJECT_NAME@_CONFIG_DIR _list_len_@PROJECT_NAME@)
+IF(NOT _list_len_@PROJECT_NAME@ EQUAL 0)
+  # Another CMake stupidity - FOREACH(... RANGE r) generates r+1 numbers ...
+  MATH(EXPR _range_@PROJECT_NAME@ "${_list_len_@PROJECT_NAME@}-1")
+  FOREACH(_p_@PROJECT_NAME@ RANGE ${_range_@PROJECT_NAME@})
+    LIST(GET _PREREQ_@PROJECT_NAME@            ${_p_@PROJECT_NAME@} _pkg_@PROJECT_NAME@    )
+    LIST(GET _PREREQ_@PROJECT_NAME@_CONFIG_DIR ${_p_@PROJECT_NAME@} _pkg_dir_@PROJECT_NAME@)
+    LIST(GET _PREREQ_@PROJECT_NAME@_COMPONENTS ${_p_@PROJECT_NAME@} _pkg_compo_@PROJECT_NAME@)
+    IF(NOT OMIT_DETECT_PACKAGE_${_pkg_@PROJECT_NAME@})
+      MESSAGE(STATUS "===> Reloading targets from ${_pkg_@PROJECT_NAME@} ...")
+      IF(NOT _pkg_compo_@PROJECT_NAME@)
+        FIND_PACKAGE(${_pkg_@PROJECT_NAME@} REQUIRED NO_MODULE
+            PATHS "${_pkg_dir_@PROJECT_NAME@}"
+            NO_DEFAULT_PATH)
+      ELSE()
+        STRING(REPLACE "," ";" _compo_lst_@PROJECT_NAME@ "${_pkg_compo_@PROJECT_NAME@}")
+        MESSAGE(STATUS "===> (components: ${_pkg_compo_@PROJECT_NAME@})")
+        FIND_PACKAGE(${_pkg_@PROJECT_NAME@} REQUIRED NO_MODULE
+            COMPONENTS ${_compo_lst_@PROJECT_NAME@}
+            PATHS "${_pkg_dir_@PROJECT_NAME@}"
+            NO_DEFAULT_PATH)
+      ENDIF()
+    ENDIF()
+  ENDFOREACH()
+ENDIF()
 
 # Installation directories
 SET(SALOME_INSTALL_BINS "@SALOME_INSTALL_BINS@")
@@ -107,22 +121,20 @@ SET(SALOME_INSTALL_RES "@SALOME_INSTALL_RES@")
 SET(SALOME_INSTALL_DOC "@SALOME_INSTALL_DOC@")
 SET(SALOME_INSTALL_AMCONFIG_LOCAL "@SALOME_INSTALL_AMCONFIG_LOCAL@")
 
-IF(SALOME_BUILD_GUI) 
+IF(SALOME_GEOM_BUILD_GUI) 
   # Include GUI targets if they were not already loaded:
   IF(NOT (TARGET Event)) 
     INCLUDE("${GUI_ROOT_DIR_EXP}/${SALOME_INSTALL_CMAKE_LOCAL}/SalomeGUITargets.cmake")
   ENDIF()
-ELSE(SALOME_BUILD_GUI) 
+ELSE(SALOME_GEOM_BUILD_GUI) 
   # Include KERNEL targets if they were not already loaded:
   IF(NOT (TARGET SALOMEBasics) AND NOT SALOME_MED_STANDALONE) 
     INCLUDE("${KERNEL_ROOT_DIR_EXP}/${SALOME_INSTALL_CMAKE}/SalomeKERNELTargets.cmake")
   ENDIF()
-ENDIF(SALOME_BUILD_GUI)
+ENDIF(SALOME_GEOM_BUILD_GUI)
 
 # Exposed GEOM targets:
 SET(GEOM_GEOMArchimede GEOMArchimede)
-SET(GEOM_BREPExport BREPExport)
-SET(GEOM_BREPImport BREPImport)
 SET(GEOM_BlockFix BlockFix)
 SET(GEOM_GEOMbasic GEOMbasic)
 SET(GEOM_GEOMAlgo GEOMAlgo)
@@ -131,13 +143,16 @@ SET(GEOM_GEOMImpl GEOMImpl)
 SET(GEOM_GEOMUtils GEOMUtils)
 SET(GEOM_GEOMEngine GEOMEngine)
 SET(GEOM_GEOM_SupervEngine GEOM_SupervEngine)
-SET(GEOM_IGESExport IGESExport)
-SET(GEOM_IGESImport IGESImport)
 SET(GEOM_GEOMSketcher GEOMSketcher)
 SET(GEOM_SalomeIDLGEOM SalomeIDLGEOM)
-SET(GEOM_STEPExport STEPExport)
-SET(GEOM_STEPImport STEPImport)
-SET(GEOM_STLExport STLExport)
+SET(GEOM_SalomeIDLGEOMSuperv SalomeIDLGEOMSuperv)
+SET(GEOM_SalomeIDLAdvancedGEOM SalomeIDLAdvancedGEOM)
+SET(GEOM_SalomeIDLSTLPlugin SalomeIDLSTLPlugin)
+SET(GEOM_SalomeIDLBREPPlugin SalomeIDLBREPPlugin)
+SET(GEOM_SalomeIDLSTEPPlugin SalomeIDLSTEPPlugin)
+SET(GEOM_SalomeIDLIGESPlugin SalomeIDLIGESPlugin)
+SET(GEOM_SalomeIDLXAOPlugin SalomeIDLXAOPlugin)
+SET(GEOM_SalomeIDLVTKPlugin SalomeIDLVTKPlugin)
 SET(GEOM_ShHealOper ShHealOper)
 SET(GEOM_XAO XAO)
 SET(GEOM_AdvancedEngine AdvancedEngine)
@@ -153,16 +168,28 @@ SET(GEOM_GEOMBase GEOMBase)
 SET(GEOM_GEOMFiltersSelection GEOMFiltersSelection)
 SET(GEOM_GEOM GEOM)
 SET(GEOM_GEOMToolsGUI GEOMToolsGUI)
+SET(GEOM_DependencyTree DependencyTree)
 SET(GEOM_GenerationGUI GenerationGUI)
 SET(GEOM_GroupGUI GroupGUI)
 SET(GEOM_Material Material)
 SET(GEOM_MeasureGUI MeasureGUI)
 SET(GEOM_GEOMObject GEOMObject)
 SET(GEOM_OCC2VTK OCC2VTK)
-SET(GEOM_VTKExport VTKExport)
 SET(GEOM_OperationGUI OperationGUI)
 SET(GEOM_PrimitiveGUI PrimitiveGUI)
 SET(GEOM_RepairGUI RepairGUI)
 SET(GEOM_TransformationGUI TransformationGUI)
-SET(GEOM_ImportExportGUI ImportExportGUI)
+SET(GEOM_STLPluginGUI STLPluginGUI)
+SET(GEOM_STLPluginEngine STLPluginEngine)
+SET(GEOM_BREPPluginGUI BREPPluginGUI)
+SET(GEOM_BREPPluginEngine BREPPluginEngine)
+SET(GEOM_STEPPluginGUI STEPPluginGUI)
+SET(GEOM_STEPPluginEngine STEPPluginEngine)
+SET(GEOM_IGESPluginGUI IGESPluginGUI)
+SET(GEOM_IGESPluginEngine IGESPluginEngine)
+SET(GEOM_XAOPluginGUI XAOPluginGUI)
+SET(GEOM_XAOPluginEngine XAOPluginEngine)
+SET(GEOM_VTKPluginGUI VTKPluginGUI)
+SET(GEOM_VTKPluginEngine VTKPluginEngine)
 SET(GEOM_GEOMShapeRec GEOMShapeRec)
+SET(GEOM_CurveCreator CurveCreator)