-# Copyright (C) 2012-2013 CEA/DEN, EDF R&D, OPEN CASCADE
+# Copyright (C) 2012-2015 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.
+# 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
STRING(TOUPPER ${PROJECT_NAME} PROJECT_NAME_UC)
SET(${PROJECT_NAME_UC}_MAJOR_VERSION 7)
-SET(${PROJECT_NAME_UC}_MINOR_VERSION 3)
-SET(${PROJECT_NAME_UC}_PATCH_VERSION 1)
+SET(${PROJECT_NAME_UC}_MINOR_VERSION 7)
+SET(${PROJECT_NAME_UC}_PATCH_VERSION 0)
SET(${PROJECT_NAME_UC}_VERSION
${${PROJECT_NAME_UC}_MAJOR_VERSION}.${${PROJECT_NAME_UC}_MINOR_VERSION}.${${PROJECT_NAME_UC}_PATCH_VERSION})
-SET(${PROJECT_NAME_UC}_VERSION_DEV 0)
+SET(${PROJECT_NAME_UC}_VERSION_DEV 1)
# Find KERNEL (optional)
# ==============
LIST(APPEND CMAKE_MODULE_PATH "${KERNEL_ROOT_DIR}/salome_adm/cmake_files")
INCLUDE(SalomeMacros)
FIND_PACKAGE(SalomeKERNEL REQUIRED)
+ KERNEL_WITH_CORBA() # check whether KERNEL builded with CORBA
ADD_DEFINITIONS(${KERNEL_DEFINITIONS} -DSALOME_KERNEL)
INCLUDE_DIRECTORIES(${KERNEL_INCLUDE_DIRS})
ELSE( EXISTS ${KERNEL_ROOT_DIR} )
SALOME_LOG_OPTIONAL_PACKAGE(SalomeKERNEL SALOME_YACS_USE_KERNEL)
ELSE( SALOME_YACS_USE_KERNEL )
MESSAGE(STATUS "Option SALOME_YACS_USE_KERNEL is set to OFF, so YACS will be built without CORBA!!!")
+ LIST(APPEND CMAKE_MODULE_PATH "${PROJECT_SOURCE_DIR}/adm/cmake")
+ INCLUDE(SalomeMacros)
ENDIF( SALOME_YACS_USE_KERNEL )
# Find SALOME GUI (optional)
# ==============
-OPTION(SALOME_BUILD_GUI "Build GUI of YACS" ON)
+CMAKE_DEPENDENT_OPTION(SALOME_BUILD_GUI "Build GUI of YACS" ON
+ "SALOME_YACS_USE_KERNEL" OFF)
IF(SALOME_BUILD_GUI)
SET(GUI_ROOT_DIR $ENV{GUI_ROOT_DIR} CACHE PATH "Path to the Salome GUI")
IF(EXISTS ${GUI_ROOT_DIR})
LIST(APPEND CMAKE_MODULE_PATH "${GUI_ROOT_DIR}/adm_local/cmake_files")
FIND_PACKAGE(SalomeGUI)
+ SALOME_GUI_WITH_CORBA() # check whether GUI builded with CORBA
+ SALOME_GUI_MODE(SALOME_USE_QXGRAPHVIEWER) # check whether GUI is built with the QxGraphViewer
ELSE(EXISTS ${GUI_ROOT_DIR})
MESSAGE(FATAL_ERROR "We absolutely need a Salome GUI, please define GUI_ROOT_DIR or turn option SALOME_BUILD_GUI to OFF !")
ENDIF(EXISTS ${GUI_ROOT_DIR})
# Local macros:
LIST(APPEND CMAKE_MODULE_PATH "${PROJECT_SOURCE_DIR}/adm/cmake")
+# additional preprocessor / compiler flags
+ADD_DEFINITIONS(-DCMAKE_BUILD)
+IF(WIN32)
+ ADD_DEFINITIONS(-DNOGDI)
+ENDIF(WIN32)
+
# User options
# ============
-ADD_DEFINITIONS(-DCMAKE_BUILD)
OPTION(SALOME_BUILD_DOC "Generate SALOME YACS documentation" ON)
OPTION(SALOME_BUILD_TESTS "Build SALOME YACS tests" ON)
OPTION(SALOME_YACS_USE_SWIG "Enable Python wrapper" ON)
OPTION(SALOME_YACS_USE_DSC "Use DSC KERNEL extension" ON)
-CMAKE_DEPENDENT_OPTION(SALOME_YACS_USE_QSCINTILLA "Use QScintilla" ON
- "SALOME_BUILD_GUI" OFF)
+
+CMAKE_DEPENDENT_OPTION(SALOME_YACS_USE_PYEDITOR "Use built-in py editor" ON
+ "SALOME_USE_PYVIEWER" OFF)
+
+IF(SALOME_YACS_USE_PYEDITOR)
+ ADD_DEFINITIONS(-DHAS_PYEDITOR)
+ENDIF(SALOME_YACS_USE_PYEDITOR)
# Advanced options:
IF(SALOME_YACS_USE_KERNEL AND SALOME_YACS_USE_DSC)
##
# Mandatory products
-FIND_PACKAGE(SalomePython REQUIRED)
+FIND_PACKAGE(SalomePythonInterp REQUIRED)
+FIND_PACKAGE(SalomePythonLibs REQUIRED)
FIND_PACKAGE(SalomePThread REQUIRED)
ADD_DEFINITIONS(-DYACS_PTHREAD)
FIND_PACKAGE(SalomeBoost REQUIRED)
FIND_PACKAGE(SalomeOmniORBPy REQUIRED)
ADD_DEFINITIONS(-DOMNIORB)
FIND_PACKAGE(SalomeLibXml2 REQUIRED)
-FIND_PACKAGE(SalomeGraphviz REQUIRED)
# Optional products:
IF(SALOME_YACS_USE_SWIG)
ENDIF()
IF(SALOME_BUILD_DOC)
- IF(SALOME_USE_MPI)
- FIND_PACKAGE(SalomeMPI) # needed for doc generation by Sphinx
- SALOME_LOG_OPTIONAL_PACKAGE(MPI SALOME_BUILD_DOC)
- ENDIF()
FIND_PACKAGE(SalomeDoxygen)
FIND_PACKAGE(SalomeSphinx)
SALOME_LOG_OPTIONAL_PACKAGE(Doxygen SALOME_BUILD_DOC)
# Find optional GUI libraries
IF(SALOME_BUILD_GUI)
+ # Graphviz
+ FIND_PACKAGE(SalomeGraphviz REQUIRED)
# Qt4
FIND_PACKAGE(SalomeQt4 REQUIRED COMPONENTS QtCore QtGui)
ENDIF(SALOME_BUILD_GUI)
-# QScintilla
-IF(SALOME_YACS_USE_QSCINTILLA)
- FIND_PACKAGE(SalomeQScintilla)
- SALOME_LOG_OPTIONAL_PACKAGE(QScintilla SALOME_YACS_USE_QSCINTILLA)
- ADD_DEFINITIONS(-DHAS_QSCI4)
-ENDIF(SALOME_YACS_USE_QSCINTILLA)
-
##
## YACS specifics
##
-FIND_PACKAGE(SalomeExpat REQUIRED)
-
# Detection summary:
SALOME_PACKAGE_REPORT_AND_CHECK()
"Install path: SALOME YACS SUPERV samples")
SET(SALOME_INSTALL_HXX2SALOME bin/HXX2SALOME_Test CACHE PATH
"Install path: SALOME HXX2SALOME Test files")
+SET(SALOME_YACS_INSTALL_TEST ${SALOME_INSTALL_SCRIPT_SCRIPTS}/test CACHE PATH
+ "Install path: SALOME YACS Test files")
MARK_AS_ADVANCED(
SALOME_YACS_INSTALL_RES_DATA
SALOME_YACS_INSTALL_RES_SCRIPTS
SALOME_YACS_INSTALL_SAMPLES
SALOME_YACS_INSTALL_SUPERV_SAMPLES
SALOME_INSTALL_HXX2SALOME
+ SALOME_YACS_INSTALL_TEST
)
# Accumulate environment variables for YACS module
# Sources
# ========
-IF(SALOME_YACS_USE_KERNEL AND NOT SALOME_LIGHT_ONLY)
+IF(SALOME_YACS_USE_KERNEL)
ADD_SUBDIRECTORY(idl)
ENDIF()
# List of targets in this project we want to make visible to the rest of the world.
# They all have to be INSTALL'd with the option "EXPORT ${PROJECT_NAME}TargetGroup"
SET(_${PROJECT_NAME}_exposed_targets
- YACSloader YACSBases YACSlibEngine YACSRuntimeSALOME
+ YACSBases YACSlibEngine
)
IF(SALOME_YACS_USE_KERNEL)
- LIST(APPEND _${PROJECT_NAME}_exposed_targets SalomeIDLYACS)
+ LIST(APPEND _${PROJECT_NAME}_exposed_targets
+ SalomeIDLYACS YACSRuntimeSALOME YACSloader
+ )
ENDIF(SALOME_YACS_USE_KERNEL)
IF(SALOME_BUILD_TESTS)
- LIST(APPEND _${PROJECT_NAME}_exposed_targets YACSDLTest PluginSimplex
- PluginOptEvTest1 TestComponentLocal yacsloader_echo)
+ LIST(APPEND _${PROJECT_NAME}_exposed_targets
+ YACSDLTest PluginSimplex PluginOptEvTest1
+ )
+ IF(SALOME_YACS_USE_KERNEL)
+ LIST(APPEND _${PROJECT_NAME}_exposed_targets
+ TestComponentLocal yacsloader_echo
+ )
+ ENDIF(SALOME_YACS_USE_KERNEL)
ENDIF(SALOME_BUILD_TESTS)
IF(SALOME_BUILD_GUI)
SET(KERNEL_ROOT_DIR "${KERNEL_ROOT_DIR}")
SET(GUI_ROOT_DIR "${GUI_ROOT_DIR}")
SET(QT4_ROOT_DIR "${QT4_ROOT_DIR}")
-SET(EXPAT_ROOT_DIR "${EXPAT_ROOT_DIR}")
-SET(QSCINTILLA_ROOT_DIR "${QSCINTILLA_ROOT_DIR}")
SET(CONF_INCLUDE_DIRS "${PROJECT_SOURCE_DIR}/include" "${PROJECT_BINARY_DIR}/include")
# Build variables that will be expanded when configuring Salome<MODULE>Config.cmake:
-SALOME_CONFIGURE_PREPARE(Expat QScintilla Qt4)
+SALOME_CONFIGURE_PREPARE(Qt4)
CONFIGURE_PACKAGE_CONFIG_FILE(${PROJECT_NAME}Config.cmake.in
${PROJECT_BINARY_DIR}/${PROJECT_NAME}Config.cmake
INSTALL_DESTINATION "${SALOME_INSTALL_CMAKE_LOCAL}"
PATH_VARS CONF_INCLUDE_DIRS SALOME_INSTALL_CMAKE_LOCAL CMAKE_INSTALL_PREFIX
- KERNEL_ROOT_DIR GUI_ROOT_DIR QT4_ROOT_DIR EXPAT_ROOT_DIR QSCINTILLA_ROOT_DIR)
+ KERNEL_ROOT_DIR GUI_ROOT_DIR QT4_ROOT_DIR)
# - in the install tree (VSR 16/08/2013: TEMPORARILY COMMENT THIS - TO REMOVE?):
# Get the relative path of the include directory so
# ${PROJECT_BINARY_DIR}/to_install/${PROJECT_NAME}Config.cmake
# INSTALL_DESTINATION "${SALOME_INSTALL_CMAKE_LOCAL}"
# PATH_VARS CONF_INCLUDE_DIRS SALOME_INSTALL_CMAKE_LOCAL CMAKE_INSTALL_PREFIX
-# KERNEL_ROOT_DIR GUI_ROOT_DIR QT4_ROOT_DIR EXPAT_ROOT_DIR QSCINTILLA_ROOT_DIR)
+# KERNEL_ROOT_DIR GUI_ROOT_DIR QT4_ROOT_DIR)
WRITE_BASIC_PACKAGE_VERSION_FILE(${PROJECT_BINARY_DIR}/${PROJECT_NAME}ConfigVersion.cmake
VERSION ${${PROJECT_NAME_UC}_VERSION}