1 # Copyright (C) 2007-2008 CEA/DEN, EDF R&D, OPEN CASCADE
3 # Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 # CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 # This library is free software; you can redistribute it and/or
7 # modify it under the terms of the GNU Lesser General Public
8 # License as published by the Free Software Foundation; either
9 # version 2.1 of the License.
11 # This library is distributed in the hope that it will be useful,
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 # Lesser General Public License for more details.
16 # You should have received a copy of the GNU Lesser General Public
17 # License along with this library; if not, write to the Free Software
18 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
25 # A set of regular expressions used ...
28 p_multiline = re.compile(r"""
34 p_dollar = re.compile(r"""
36 (?P<val> # open the group val
37 [^)]* # the group contain 0 or more non ) characters
42 p_arobas = re.compile(r"""
44 (?P<val> # open the group val
45 [^@]* # the group contain 0 or more non @ characters
50 p_if = re.compile(r"""
51 ^ # beginning of the string
55 (?P<val> # open the group val
56 [^\s]+ # the group contain 1 or more non space characters
60 p_else = re.compile(r"""
61 ^ # beginning of the line
67 p_endif = re.compile(r"""
68 ^ # beginning of the line
74 p_attribution = re.compile(r"""
75 ^ # beginning of the line
76 (?P<spaces> # open the group spaces
79 (?P<key> # open the group key
80 \w+ # the group contain 1 or more alphanumeric characters
83 (?P<method> # open the group method
87 (?P<value> # open the group value
88 .* # 0 or more any characters
94 class CMakeFile(object):
96 def __init__(self, the_root, root, dirs, files, f, module):
98 self.the_root = the_root
104 from os.path import join
105 self.amFile = join(root, f)
106 self.listsFile = join(root, "CMakeLists.txt")
115 # Read the Makefile.am file
118 stream = open(amFile)
119 content = stream.read()
123 # Replace the composed lines separated by "\\n" by an unique line
125 content = p_multiline.sub(r' ', content)
128 # Compatibility netgen plugin
130 content = content.replace("../NETGEN/libNETGEN.la", "${NETGEN_LIBS}")
205 "vtkGraphicsPythonD",
217 "SalomeCommunication",
219 "SalomeDSCContainer",
227 "SalomeLifeCycleCORBA",
229 "SalomeLoggerServer",
230 "SalomeNotification",
232 "SalomeResourcesManager",
234 "with_loggerTraceCollector",
286 "GEOMFiltersSelection",
310 "InterpGeometric2DAlg",
339 "SMESHFiltersSelection",
347 full_list = cas_list + vtk_list
348 full_list += kernel_list + gui_list
349 full_list += geom_list + med_list + smesh_list
351 # E.A. : sort by len before substitution ...
352 # Why ? Thing to "-lMEDWrapper" then "-lMEDWrapper_V2_1" substition
353 # And you understand ...
355 full_list.sort(cmp = lambda x, y : cmp(len(y), len(x)))
357 for key in full_list:
358 content = content.replace("-l%s"%(key), "${%s}"%(key))
362 # Split content in lines to treat each one separately
364 lines = content.split('\n')
367 # newlines contains the lines of the future CMakeLists.txt file
372 # opened_ifs is used to deals with nested conditionnals
377 # the __thedict__ dictionnary contains key, val
378 # of the Makefile.am file
380 self.__thedict__ = {}
383 # Initialize file ... mainly includes other cmake files
385 self.initialize(newlines)
388 # Do the job for each line
391 self.treatLine(line, newlines, opened_ifs)
395 # Finalize file ... it is in here the cmake job is done
397 self.finalize(newlines)
400 # Concatenate newlines into content
402 content = '\n'.join(newlines)
405 # Add a CR at end if necessary
407 lines = content.split('\n')
408 # lines = [ l.strip() for l in lines ]
409 if len(lines[-1]) != 0:
412 content = '\n'.join(lines)
415 self.content = content
420 def initialize(self, newlines):
421 if self.root == self.the_root:
424 CMAKE_MINIMUM_REQUIRED(VERSION 2.4.7 FATAL_ERROR)
425 IF(COMMAND cmake_policy)
426 cmake_policy(SET CMP0003 NEW)
427 ENDIF(COMMAND cmake_policy)
430 if self.module == "kernel":
432 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindPLATFORM.cmake)
433 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindPYTHON.cmake)
434 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindOMNIORB.cmake)
435 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindPTHREADS.cmake)
436 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindHDF5.cmake)
437 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindBOOST.cmake)
438 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindLIBXML2.cmake)
439 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindSWIG.cmake)
440 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindCPPUNIT.cmake)
445 SET(KERNEL_ROOT_DIR $ENV{KERNEL_ROOT_DIR})
446 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindPLATFORM.cmake)
447 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindPYTHON.cmake)
448 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindOMNIORB.cmake)
449 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindPTHREADS.cmake)
450 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindHDF5.cmake)
451 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindBOOST.cmake)
452 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindLIBXML2.cmake)
453 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindSWIG.cmake)
454 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindCPPUNIT.cmake)
455 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindKERNEL.cmake)
457 if self.module == "gui":
459 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindCAS.cmake)
460 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindQT4.cmake)
461 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindOPENGL.cmake)
462 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindVTK.cmake)
463 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindQWT.cmake)
464 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindSIPPYQT.cmake)
468 SET(GUI_ROOT_DIR $ENV{GUI_ROOT_DIR})
469 INCLUDE(${GUI_ROOT_DIR}/adm_local/cmake_files/FindCAS.cmake)
470 INCLUDE(${GUI_ROOT_DIR}/adm_local/cmake_files/FindQT4.cmake)
471 INCLUDE(${GUI_ROOT_DIR}/adm_local/cmake_files/FindOPENGL.cmake)
472 INCLUDE(${GUI_ROOT_DIR}/adm_local/cmake_files/FindVTK.cmake)
473 INCLUDE(${GUI_ROOT_DIR}/adm_local/cmake_files/FindQWT.cmake)
474 INCLUDE(${GUI_ROOT_DIR}/adm_local/cmake_files/FindSIPPYQT.cmake)
475 INCLUDE(${GUI_ROOT_DIR}/adm_local/cmake_files/FindGUI.cmake)
477 if self.module == "med":
479 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindMEDFILE.cmake)
482 if self.module == "smesh":
484 SET(GEOM_ROOT_DIR $ENV{GEOM_ROOT_DIR})
485 SET(MED_ROOT_DIR $ENV{MED_ROOT_DIR})
486 INCLUDE(${GEOM_ROOT_DIR}/adm_local/cmake_files/FindGEOM.cmake)
487 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMEDFILE.cmake)
488 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMED.cmake)
491 if self.module == "netgenplugin":
493 SET(GEOM_ROOT_DIR $ENV{GEOM_ROOT_DIR})
494 SET(MED_ROOT_DIR $ENV{MED_ROOT_DIR})
495 SET(SMESH_ROOT_DIR $ENV{SMESH_ROOT_DIR})
496 INCLUDE(${GEOM_ROOT_DIR}/adm_local/cmake_files/FindGEOM.cmake)
497 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMED.cmake)
498 INCLUDE(${SMESH_ROOT_DIR}/adm_local/cmake_files/FindSMESH.cmake)
499 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindNETGEN.cmake)
502 if self.module == "blsurfplugin":
504 SET(GEOM_ROOT_DIR $ENV{GEOM_ROOT_DIR})
505 SET(MED_ROOT_DIR $ENV{MED_ROOT_DIR})
506 SET(SMESH_ROOT_DIR $ENV{SMESH_ROOT_DIR})
507 INCLUDE(${GEOM_ROOT_DIR}/adm_local/cmake_files/FindGEOM.cmake)
508 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMED.cmake)
509 INCLUDE(${SMESH_ROOT_DIR}/adm_local/cmake_files/FindSMESH.cmake)
510 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindBLSURF.cmake)
513 if self.module == "visu":
515 SET(MED_ROOT_DIR $ENV{MED_ROOT_DIR})
516 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMED.cmake)
522 if self.module == "kernel":
527 set(XVERSION 0x050102)
528 SET(CALCIUM_IDL_INT_F77 long)
529 SET(CALCIUM_CORBA_INT_F77 CORBA::Long)
532 elif self.module == "gui":
534 SET(GUI_ENABLE_CORBA ${CORBA_GEN})
535 SET(ENABLE_VTKVIEWER ON)
536 SET(ENABLE_SALOMEOBJECT ON)
537 SET(ENABLE_OCCVIEWER ON)
538 SET(ENABLE_GLVIEWER ON)
539 SET(ENABLE_PLOT2DVIEWER ON)
540 SET(ENABLE_PYCONSOLE ON)
541 SET(ENABLE_SUPERVGRAPHVIEWER ON)
542 # SET(ENABLE_QXGRAPHVIEWER ON)
544 set(XVERSION 0x050102)
547 elif self.module == "geom":
549 SET(GEOM_ENABLE_GUI ON)
552 elif self.module == "medfile":
554 SET(MED_NUM_MAJEUR 2)
555 SET(MED_NUM_MINEUR 3)
556 SET(MED_NUM_RELEASE 5)
559 SET(FLIBS -lgfortranbegin -lgfortran)
563 elif self.module == "med":
565 SET(MED_ENABLE_KERNEL ON)
566 SET(MED_ENABLE_GUI ON)
569 elif self.module == "smesh":
571 SET(SMESH_ENABLE_GUI ON)
574 elif self.module == "netgenplugin":
576 SET(NETGENPLUGIN_ENABLE_GUI ON)
579 elif self.module == "blsurfplugin":
581 SET(BLSURFPLUGIN_ENABLE_GUI ON)
588 SET(VERSION_INFO 0.0.0)
589 SET(SOVERSION_INFO 0)
598 def treatLine(self, line, newlines, opened_ifs):
601 # Print the comment above the line itself
603 if line.find('#') >= 0:
604 fields = line.split('#')
606 comment = '#'.join([''] + fields[1:])
607 newlines.append(comment)
613 # If the line begins with 'include ', just comment it
615 if line.find("include ") == 0:
616 newlines.append("# " + line)
620 # If the line begins with '-include', just comment it
622 if line.find("-include") == 0:
623 newlines.append("# " + line)
627 # If the line is a definition of a make rule, just comment it
629 if line.count(':') == 1:
630 newlines.append("# " + line)
634 # A particuliar case where there are two ":" on the same line
636 if line.find('install-exec-local:') == 0:
637 newlines.append("# " + line)
641 # If the line begin by a tabulation, consider it's a makefile command and comment it
643 if line.find("\t") == 0:
644 newlines.append("# " + line)
649 key = "-version-info"
650 if line.find(key) >= 0:
652 before = line.split(key)[0]
653 after = line[len(before)+len(key):]
656 version_info = after.split()[0]
657 line = line.replace(key+sep+version_info, "")
659 version_info = version_info.replace(':', '.')
660 soversion_info = version_info.split('.')[0]
661 newlines.append("SET(VERSION_INFO " + version_info + ")")
662 newlines.append("SET(SOVERSION_INFO " + soversion_info + ")")
667 # Replace the $(TOTO) by ${TOTO}
668 # Replace the @TOTO@ by ${TOTO}
670 line = p_dollar.sub(r"${\1}", line)
671 line = p_arobas.sub(r"${\1}", line)
674 line = line.replace(r"${top_builddir}", r"${CMAKE_BINARY_DIR}")
675 line = line.replace(r"${top_srcdir}", r"${CMAKE_SOURCE_DIR}")
676 line = line.replace(r"${srcdir}", r"${CMAKE_CURRENT_SOURCE_DIR}")
677 line = line.replace(r"${builddir}", r"${CMAKE_CURRENT_BINARY_DIR}")
678 line = line.replace(r"${datadir}", r"${CMAKE_INSTALL_PREFIX}/share")
681 # Check if the line is a 'if' condition
682 # If yes, replace it by a cmake grammar
684 match = p_if.match(line)
686 theif = match.group("val")
688 theif = "NOT " + theif[1:]
690 line = p_if.sub(r"IF(%s)"%(theif), line)
691 opened_ifs.append(theif)
692 newlines.append(line)
696 # Check if the line is a 'else' condition
697 # If yes, replace it by a cmake grammar
699 match = p_else.match(line)
701 line = "ELSE(%s)"%(opened_ifs[-1])
702 newlines.append(line)
706 # Check if the line is a 'endif' condition
707 # If yes, replace it by a cmake grammar
709 match = p_endif.match(line)
711 line = "ENDIF(%s)"%(opened_ifs[-1])
713 newlines.append(line)
717 # Check if the line is an attribution '=' or '+='
719 match = p_attribution.match(line)
721 self.treatAttribution(match, newlines)
725 newlines.append(line)
730 def treatAttribution(self, match, newlines):
732 spaces = match.group("spaces")
733 key = match.group("key")
734 method = match.group("method")
735 value = match.group("value")
736 # print [spaces, key, method, value]
739 # Open cmake SET command
741 newlines.append(spaces + "SET(" + key)
744 # If method is '+=', put the previous definition as first value
747 newlines.append("%s ${%s}"%(spaces, key))
751 fields = value.split()
752 for i in range(len(fields)):
753 newlines.append("%s %s"%(spaces, fields[i]))
759 # The try: except KeyError is here if the +=
760 # is an error which occurs in salome ...
763 self.__thedict__[key] += fields[:]
765 self.__thedict__[key] = fields[:]
769 self.__thedict__[key] = fields[:]
773 # Close cmake SET command
776 newlines.append("%s)"%(spaces))
780 def finalize(self, newlines):
783 # Convert the .in files in build dir
787 if f == "sstream.in":
789 if f in ["runContainer.in", "stopContainer.in"]:
790 if self.module == "med":
791 if self.root[-3:] == "csh":
795 if f == "SALOMEconfig.ref.in":
796 out = "SALOMEconfig.h"
801 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/%s)
804 SET(output ${CMAKE_CURRENT_BINARY_DIR}/%s)
807 MESSAGE(STATUS "Creation of ${output}")
808 CONFIGURE_FILE(${input} ${output})
814 # convert the SUBDIRS in cmake grammar
816 if 1: # self.__thedict__.has_key("SUBDIRS"):
818 FOREACH(dir ${SUBDIRS})
819 IF(NOT dir STREQUAL .)
820 ADD_SUBDIRECTORY(${dir})
821 ENDIF(NOT dir STREQUAL .)
822 ENDFOREACH(dir ${SUBDIRS})
828 for key in ["lib_LTLIBRARIES", "noinst_LTLIBRARIES", "salomepyexec_LTLIBRARIES"]:
829 if self.__thedict__.has_key(key):
830 self.addLibTarget(key, newlines)
836 for key in ["bin_PROGRAMS"]:
837 if self.__thedict__.has_key(key):
838 self.addBinTarget(key, newlines)
844 if self.__thedict__.has_key("BASEIDL_FILES"):
845 if not self.__thedict__.has_key("IDL_FILES"):
846 self.__thedict__["IDL_FILES"] = self.__thedict__["BASEIDL_FILES"]
848 SET(IDL_FILES ${BASEIDL_FILES})
857 if self.__thedict__.has_key(key):
858 if self.module == "kernel":
860 SET(IDL_FILES ${IDL_FILES} Calcium_Ports.idl)
864 FOREACH(input ${IDL_FILES})
865 STRING(REGEX REPLACE ".idl" "" base ${input})
866 SET(src ${CMAKE_CURRENT_BINARY_DIR}/${base}SK.cc)
868 SET(dynsrc ${CMAKE_CURRENT_BINARY_DIR}/${base}DynSK.cc)
869 SET(outputs ${outputs} ${dynsrc})
870 IF(input STREQUAL Calcium_Ports.idl)
871 SET(input ${CMAKE_CURRENT_BINARY_DIR}/${input})
872 ELSE(input STREQUAL Calcium_Ports.idl)
873 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${input})
874 ENDIF(input STREQUAL Calcium_Ports.idl)
877 COMMAND ${OMNIORB_IDL} ${IDLCXXFLAGS} ${OMNIORB_IDLCXXFLAGS} ${input}
878 MAIN_DEPENDENCY ${input}
880 install(FILES ${input} DESTINATION idl/salome)
881 SET(IDL_HEADER ${CMAKE_CURRENT_BINARY_DIR}/${base}.hh)
882 install(FILES ${IDL_HEADER} DESTINATION include/salome)
883 INSTALL(CODE "SET(IDL_FILE ${input})")
884 INSTALL(CODE "SET(DIR lib/python${PYTHON_VERSION}/site-packages/salome)")
885 INSTALL(CODE "SET(CMAKE_CURRENT_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR})")
886 INSTALL(CODE "SET(OMNIORB_IDL_PYTHON ${OMNIORB_IDL_PYTHON})")
889 FOREACH(f ${IDLPYFLAGS})
890 SET(flags "${flags} ${f}")
891 ENDFOREACH(f ${IDLPYFLAGS})
892 SET(IDLPYFLAGS ${flags})
893 STRING(REPLACE "\\\\" "/" IDLPYFLAGS ${IDLPYFLAGS})
894 INSTALL(CODE "SET(IDLPYFLAGS ${IDLPYFLAGS})")
897 if self.module == "kernel":
899 INSTALL(SCRIPT ${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/install_python_from_idl.cmake)
903 STRING(REPLACE "\\\\" "/" KERNEL_ROOT_DIR ${KERNEL_ROOT_DIR})
904 INSTALL(SCRIPT ${KERNEL_ROOT_DIR}/salome_adm/cmake_files/install_python_from_idl.cmake)
908 ENDFOREACH(input ${IDL_FILES})
914 for key in ["SWIG_SRC", "SWIGSOURCES", "SWIG_DEF"]:
915 if self.__thedict__.has_key(key):
917 SET(SWIG_SOURCES ${%s})
919 self.__thedict__["SWIG_SOURCES"] = self.__thedict__[key]
925 if self.__thedict__.has_key("SWIG_SOURCES"):
927 IF(SWIG_SOURCES MATCHES ";")
928 STRING(REGEX REPLACE ";.*" "" SWIG_SOURCES_FIRST "${SWIG_SOURCES}")
929 ELSE(SWIG_SOURCES MATCHES ";")
930 SET(SWIG_SOURCES_FIRST "${SWIG_SOURCES}")
931 ENDIF(SWIG_SOURCES MATCHES ";")
934 COMMAND ${SWIG_EXECUTABLE} ${SWIG_FLAGS} ${MY_SWIG_FLAGS} -o ${build_srcs} ${CMAKE_CURRENT_SOURCE_DIR}/${SWIG_SOURCES_FIRST}
935 MAIN_DEPENDENCY ${SWIG_SOURCES}
943 if self.__thedict__.has_key(key):
945 FOREACH(output ${MOC_FILES})
946 STRING(REGEX REPLACE _moc.cxx .h input ${output})
947 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${input})
948 SET(output ${CMAKE_CURRENT_BINARY_DIR}/${output})
951 COMMAND ${QT_MOC_EXECUTABLE} ${MOC_FLAGS} ${input} -o ${output}
952 MAIN_DEPENDENCY ${input}
954 ENDFOREACH(output ${MOC_FILES})
961 if self.__thedict__.has_key(key):
963 FOREACH(output ${UIC_FILES})
964 STRING(REPLACE "ui_" "" input ${output})
965 STRING(REPLACE ".h" ".ui" input ${input})
966 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${input})
967 SET(output ${CMAKE_CURRENT_BINARY_DIR}/${output})
970 COMMAND ${QT_UIC_EXECUTABLE} -o ${output} ${input}
971 MAIN_DEPENDENCY ${input}
973 ENDFOREACH(output ${UIC_FILES})
980 if self.__thedict__.has_key(key):
982 FOREACH(output ${QRC_FILES})
983 STRING(REGEX REPLACE "qrc_" "" input ${output})
984 STRING(REGEX REPLACE ".cxx" ".qrc" input ${input})
985 STRING(REGEX REPLACE ".qrc" "" name ${input})
986 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${input})
987 SET(output ${CMAKE_CURRENT_BINARY_DIR}/${output})
990 COMMAND ${QT_RCC_EXECUTABLE} ${input} -o ${output} -name ${name}
991 MAIN_DEPENDENCY ${input}
993 ENDFOREACH(output ${QRC_FILES})
1000 if self.__thedict__.has_key(key):
1002 FOREACH(input ${SIP_FILES})
1003 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${input})
1005 FOREACH(out ${SIP_SRC})
1006 SET(output ${output} ${CMAKE_CURRENT_BINARY_DIR}/${out})
1007 ENDFOREACH(out ${SIP_SRC})
1010 COMMAND ${SIP_EXECUTABLE} ${PYQT_SIPFLAGS} ${input}
1011 MAIN_DEPENDENCY ${input}
1013 ENDFOREACH(input ${SIP_FILES})
1018 # Treat the install targets
1021 "salomeadmux_DATA" : "salome_adm/unix",
1022 "dist_salomeadmux_DATA" : "salome_adm/unix",
1023 "dist_salome_cmake_DATA" : "salome_adm/cmake_files",
1024 "dist_salomem4_DATA" : "salome_adm/unix/config_files",
1025 "dist_salome4depr_DATA" : "salome_adm/unix/config_files/DEPRECATED",
1026 "dist_admlocalm4_DATA" : "adm_local/unix/config_files",
1027 "dist_admlocal_cmake_DATA" : "adm_local/cmake_files",
1028 "salomeinclude_DATA" : "include/salome",
1029 "salomeinclude_HEADERS" : "include/salome",
1030 "dist_salomeres_DATA" : "share/salome/resources/%s"%(self.module),
1031 "nodist_salomeres_DATA" : "share/salome/resources/%s"%(self.module),
1032 "nodist_salomeres_SCRIPTS" : "share/salome/resources/%s"%(self.module),
1033 "dist_salomescript_SCRIPTS" : "bin/salome",
1034 "dist_salomescript_DATA" : "bin/salome",
1035 "dist_salomescript_PYTHON" : "bin/salome",
1036 "nodist_salomescript_DATA" : "bin/salome",
1037 "salomepython_PYTHON" : "lib/python${PYTHON_VERSION}/site-packages/salome",
1038 "nodist_salomepython_PYTHON" : "lib/python${PYTHON_VERSION}/site-packages/salome",
1039 "sharedpkgpython_PYTHON" : "lib/python${PYTHON_VERSION}/site-packages/salome/shared_modules",
1041 if self.module == "medfile":
1043 "include_HEADERS" : "include",
1044 "nodist_include_HEADERS" : "include",
1045 "bin_SCRIPTS" : "bin",
1046 "doc_DATA" : "${docdir}",
1049 for key, value in d.items():
1050 if self.__thedict__.has_key(key):
1051 self.addInstallTarget(key, value, newlines)
1058 def setLibAdd(self, key, newlines):
1060 newlines.append(r'''
1064 newlines.append(r'''
1067 SET(targets ${targets} MEFISTO2D)
1068 FOREACH(target ${targets})
1069 IF(name STREQUAL ${target})
1070 SET(dir $ENV{F2CHOME})
1071 STRING(REPLACE "\\\\" "/" dir ${dir})
1072 SET(libadd ${libadd} ${dir}/LIBF77.lib)
1073 SET(libadd ${libadd} ${dir}/LIBI77.lib)
1074 ENDIF(name STREQUAL ${target})
1075 ENDFOREACH(target ${targets})
1079 newlines.append(r'''
1080 SET(libs ${PLATFORM_LIBADD} ${PLATFORM_LDFLAGS} ${${amname}_LIBADD} ${${amname}_LDADD} ${${amname}_LDFLAGS})
1081 FOREACH(lib SALOMEBasics SalomeBatch)
1082 IF(name STREQUAL lib)
1083 SET(libs ${libs} ${PTHREAD_LIBS})
1084 ENDIF(name STREQUAL lib)
1085 ENDFOREACH(lib SALOMEBasics SalomeBatch)
1087 if key == "bin_PROGRAMS":
1088 newlines.append(r'''
1089 SET(libs ${libs} ${LDADD})
1093 newlines.append(r'''
1094 FOREACH(lib ${libs})
1095 GET_FILENAME_COMPONENT(ext ${lib} EXT)
1096 IF(ext STREQUAL .la)
1097 GET_FILENAME_COMPONENT(lib ${lib} NAME_WE)
1098 STRING(REPLACE "lib" "" lib ${lib})
1099 ENDIF(ext STREQUAL .la)
1101 SET(vars ${vars} -no-undefined)
1103 SET(vars ${vars} -module)
1104 SET(vars ${vars} -Wl,-E)
1105 SET(vars ${vars} -Xlinker)
1106 SET(vars ${vars} -export-dynamic)
1107 SET(vars ${vars} -lm)
1108 SET(vars ${vars} -lboost_thread)
1109 SET(vars ${vars} -lboost_signals)
1110 SET(vars ${vars} -lvtkWidgets)
1115 ENDIF(lib STREQUAL v)
1116 ENDFOREACH(v ${vars})
1117 SET(libadd ${libadd} ${lib})
1118 ENDFOREACH(lib ${libs})
1119 TARGET_LINK_LIBRARIES(${name} ${libadd})
1122 newlines.append(r'''
1125 SET(targets ${targets} MEFISTO2D)
1126 FOREACH(target ${targets})
1127 IF(name STREQUAL ${target})
1128 IF(CMAKE_BUILD_TYPE STREQUAL Debug)
1129 SET_TARGET_PROPERTIES(${name} PROPERTIES LINK_FLAGS "/NODEFAULTLIB:MSVCRT")
1130 ENDIF(CMAKE_BUILD_TYPE STREQUAL Debug)
1131 ENDIF(name STREQUAL ${target})
1132 ENDFOREACH(target ${targets})
1138 def setCompilationFlags(self, key, newlines):
1139 newlines.append(r'''
1143 SET(targets ${targets} SalomeIDLKernel)
1144 SET(targets ${targets} SalomeDS)
1145 SET(targets ${targets} SALOMEDSTest)
1146 SET(targets ${targets} SALOMEDS_Client_exe)
1147 SET(targets ${targets} SalomeIDLGEOM)
1148 SET(targets ${targets} GEOMEngine)
1149 SET(targets ${targets} MEDEngine)
1150 SET(targets ${targets} SMESHEngine)
1151 SET(targets ${targets} SMESH)
1152 FOREACH(target ${targets})
1153 IF(name STREQUAL ${target})
1154 SET(var ${var} -DNOGDI)
1155 ENDIF(name STREQUAL ${target})
1156 ENDFOREACH(target ${targets})
1160 newlines.append(r'''
1163 SET(targets ${targets} MEFISTO2D)
1164 FOREACH(target ${targets})
1165 IF(name STREQUAL ${target})
1166 SET(dir $ENV{F2CHOME})
1167 STRING(REPLACE "\\\\" "/" dir ${dir})
1168 SET(var ${var} -I${dir})
1169 ENDIF(name STREQUAL ${target})
1170 ENDFOREACH(target ${targets})
1174 if self.module in ["geom", "med"]:
1175 newlines.append(r'''
1176 SET(var ${var} -I${CMAKE_CURRENT_SOURCE_DIR})
1177 SET(var ${var} -I${CMAKE_CURRENT_BINARY_DIR})
1180 if key == "bin_PROGRAMS":
1181 newlines.append(r'''
1182 SET(var ${var} ${AM_CPPFLAGS})
1183 SET(var ${var} ${AM_CXXFLAGS})
1186 newlines.append(r'''
1187 SET(var ${var} ${PLATFORM_CPPFLAGS})
1188 SET(var ${var} ${PTHREAD_CFLAGS})
1189 SET(var ${var} ${${amname}_CPPFLAGS})
1190 SET(var ${var} ${${amname}_CXXFLAGS})
1191 SET(var ${var} ${${amname}_CFLAGS})
1194 SET(vars ${vars} -include SALOMEconfig.h)
1195 SET(vars ${vars} -ftemplate-depth-32)
1203 ENDFOREACH(v ${vars})
1204 SET(flags "${flags} ${f}")
1205 ENDFOREACH(f ${var})
1206 SET_TARGET_PROPERTIES(${name} PROPERTIES COMPILE_FLAGS "${flags}")
1210 def addLibTarget(self, key, newlines):
1211 newlines.append(r'''
1212 FOREACH(amname ${%s})
1215 # Replace .la by _la ...
1217 newlines.append(r'''
1218 STRING(REPLACE .la _la amname ${amname})
1221 # Remove the _la for the cmake name
1223 newlines.append(r'''
1224 STRING(LENGTH ${amname} len)
1225 MATH(EXPR newlen "${len}-3")
1226 STRING(SUBSTRING ${amname} 0 ${newlen} name)
1229 # Does the target begins with lib ??
1230 # If yes, remove lib at beginning for cmake name
1232 newlines.append(r'''
1233 STRING(REGEX MATCH "^lib" BEGIN_WITH_lib ${name})
1235 STRING(LENGTH ${name} len)
1236 MATH(EXPR newlen "${len}-3")
1237 STRING(SUBSTRING ${name} 3 ${newlen} name)
1238 ENDIF(BEGIN_WITH_lib)
1241 # Does the target is an idl library
1243 newlines.append(r'''
1244 STRING(REGEX MATCH "IDL" ISIDL ${name})
1247 # Set the type of the library
1249 newlines.append(r'''
1261 # Set sources for the library
1263 newlines.append(r'''
1265 FOREACH(src ${${amname}_SOURCES} ${dist_${amname}_SOURCES})
1266 GET_FILENAME_COMPONENT(ext ${src} EXT)
1268 IF(src STREQUAL trte.f)
1269 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${src})
1270 STRING(REPLACE ".f" ".c" src ${src})
1271 SET(src ${CMAKE_CURRENT_BINARY_DIR}/${src})
1275 COMMAND f2c ${input}
1276 MAIN_DEPENDENCY ${input}
1278 ELSE(src STREQUAL trte.f)
1279 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${src})
1280 STRING(REPLACE ".f" ".o" src ${src})
1281 SET(src ${CMAKE_CURRENT_BINARY_DIR}/${src})
1290 COMMAND ${F77} -c -o ${output} ${input}
1291 MAIN_DEPENDENCY ${input}
1293 ENDIF(src STREQUAL trte.f)
1294 ENDIF(ext STREQUAL .f)
1295 SET(srcs ${srcs} ${src})
1296 ENDFOREACH(src ${${amname}_SOURCES} ${dist_${amname}_SOURCES})
1298 newlines.append(r'''
1301 newlines.append(r'''
1302 SET(l ${nodist_${amname}_SOURCES} ${BUILT_SOURCES})
1304 newlines.append(r'''
1306 GET_FILENAME_COMPONENT(ext ${f} EXT)
1307 IF(ext STREQUAL .py)
1308 ELSE(ext STREQUAL .py)
1309 SET(build_srcs ${build_srcs} ${CMAKE_CURRENT_BINARY_DIR}/${f})
1310 ENDIF(ext STREQUAL .py)
1312 SET(srcs ${build_srcs} ${srcs})
1315 # Add the library to cmake
1317 newlines.append(r'''
1318 ADD_LIBRARY(${name} ${type} ${srcs})
1321 # The compilation flags
1323 self.setCompilationFlags(key, newlines)
1325 newlines.append(r'''
1326 SET_TARGET_PROPERTIES(${name} PROPERTIES VERSION ${VERSION_INFO} SOVERSION ${SOVERSION_INFO})
1329 self.setLibAdd(key, newlines)
1331 if 1: # key != "noinst_LTLIBRARIES":
1332 if self.module == "medfile":
1333 newlines.append(r'''
1337 newlines.append(r'''
1338 SET(DEST lib/salome)
1341 newlines.append(r'''
1343 INSTALL(TARGETS ${name} DESTINATION ${DEST})
1345 if self.module == "gui":
1346 newlines.append(r'''
1347 FOREACH(lib SalomePyQt)
1348 IF(name STREQUAL lib)
1350 IF(CMAKE_BUILD_TYPE STREQUAL Release)
1351 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.dll DESTINATION ${DEST} RENAME ${name}.pyd)
1352 ELSE(CMAKE_BUILD_TYPE STREQUAL Release)
1353 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.dll DESTINATION ${DEST} RENAME ${name}_d.pyd)
1354 ENDIF(CMAKE_BUILD_TYPE STREQUAL Release)
1356 INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/lib${name}.so DESTINATION ${DEST} RENAME ${name}.so)
1358 ENDIF(name STREQUAL lib)
1359 ENDFOREACH(lib SalomePyQt)
1360 FOREACH(lib SalomePy)
1361 IF(name STREQUAL lib)
1363 IF(CMAKE_BUILD_TYPE STREQUAL Release)
1364 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.dll DESTINATION ${DEST} RENAME lib${name}.pyd)
1365 ELSE(CMAKE_BUILD_TYPE STREQUAL Release)
1366 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.dll DESTINATION ${DEST} RENAME lib${name}_d.pyd)
1367 ENDIF(CMAKE_BUILD_TYPE STREQUAL Release)
1369 ENDIF(name STREQUAL lib)
1370 ENDFOREACH(lib SalomePy)
1373 if self.module == "geom":
1374 newlines.append(r'''
1376 STRING(REGEX MATCH "Export" ISExport ${name})
1378 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.dll DESTINATION ${DEST} RENAME lib${name}.dll)
1380 STRING(REGEX MATCH "Import" ISImport ${name})
1382 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.dll DESTINATION ${DEST} RENAME lib${name}.dll)
1387 newlines.append(r'''
1388 ELSE(BEGIN_WITH_lib)
1390 newlines.append(r'''
1392 INSTALL(TARGETS ${name} DESTINATION lib/python${PYTHON_VERSION}/site-packages/salome)
1393 IF(CMAKE_BUILD_TYPE STREQUAL Release)
1394 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/lib/python${PYTHON_VERSION}/site-packages/salome/${name}.dll DESTINATION lib/python${PYTHON_VERSION}/site-packages/salome RENAME ${name}.pyd)
1395 ELSE(CMAKE_BUILD_TYPE STREQUAL Release)
1396 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/lib/python${PYTHON_VERSION}/site-packages/salome/${name}.dll DESTINATION lib/python${PYTHON_VERSION}/site-packages/salome RENAME ${name}_d.pyd)
1397 ENDIF(CMAKE_BUILD_TYPE STREQUAL Release)
1399 GET_TARGET_PROPERTY(version ${name} VERSION)
1400 GET_TARGET_PROPERTY(soversion ${name} SOVERSION)
1401 INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/lib${name}.so.${version} DESTINATION lib/python${PYTHON_VERSION}/site-packages/salome RENAME ${name}.so.${version})
1402 INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/lib${name}.so.${version} DESTINATION lib/python${PYTHON_VERSION}/site-packages/salome RENAME ${name}.so.${soversion})
1403 INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/lib${name}.so.${version} DESTINATION lib/python${PYTHON_VERSION}/site-packages/salome RENAME ${name}.so)
1406 newlines.append(r'''
1407 ENDIF(BEGIN_WITH_lib)
1411 newlines.append(r'''
1412 ENDFOREACH(amname ${%s})
1417 def addBinTarget(self, key, newlines):
1419 newlines.append(r'''
1420 FOREACH(amname ${bin_PROGRAMS})
1423 newlines.append(r'''
1424 SET(name "${amname}_exe")
1425 SET(srcs ${${amname}_SOURCES} ${dist_${amname}_SOURCES})
1426 LIST(LENGTH srcs nb)
1428 ADD_EXECUTABLE(${name} ${srcs})
1431 self.setCompilationFlags(key, newlines)
1433 self.setLibAdd(key, newlines)
1435 if self.module == "medfile":
1436 newlines.append(r'''
1440 newlines.append(r'''
1441 SET(DEST bin/salome)
1445 newlines.append(r'''
1447 INSTALL(TARGETS ${name} DESTINATION ${DEST})
1448 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.exe DESTINATION ${DEST} RENAME ${amname}.exe)
1449 INSTALL(CODE "FILE(REMOVE ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.exe)")
1452 SET(PERMS ${PERMS} OWNER_READ OWNER_WRITE OWNER_EXECUTE)
1453 SET(PERMS ${PERMS} GROUP_READ GROUP_EXECUTE)
1454 SET(PERMS ${PERMS} WORLD_READ WORLD_EXECUTE)
1455 INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/${name} DESTINATION ${DEST} PERMISSIONS ${PERMS} RENAME ${amname})
1459 newlines.append(r'''
1463 newlines.append(r'''
1464 ENDFOREACH(amname ${bin_PROGRAMS})
1469 def addInstallTarget(self, key, destination, newlines):
1470 newlines.append(r"FOREACH(f ${%s})"%(key))
1471 newlines.append(r'''
1474 newlines.append(r'''
1475 STRING(COMPARE EQUAL ${f} SALOMEconfig.h.in test_SALOMEconfig.h.in)
1476 IF(test_SALOMEconfig.h.in)
1477 INSTALL(FILES SALOMEconfig.ref.in DESTINATION ${DEST} RENAME SALOMEconfig.h.in)
1478 ELSE(test_SALOMEconfig.h.in)
1479 SET(dummy dummy-NOTFOUND)
1480 MARK_AS_ADVANCED(dummy)
1481 # FILE(REMOVE ${CMAKE_INSTALL_PREFIX}/${DEST}/${f})
1482 FIND_FILE(dummy ${f} PATHS ${CMAKE_CURRENT_SOURCE_DIR} NO_DEFAULT_PATH)
1485 if key in ['dist_salomescript_SCRIPTS']:
1486 newlines.append(r'''
1488 SET(PERMS ${PERMS} OWNER_READ OWNER_WRITE OWNER_EXECUTE)
1489 SET(PERMS ${PERMS} GROUP_READ GROUP_EXECUTE)
1490 SET(PERMS ${PERMS} WORLD_READ WORLD_EXECUTE)
1491 INSTALL(FILES ${f} DESTINATION ${DEST} PERMISSIONS ${PERMS})
1494 newlines.append(r'''
1495 GET_FILENAME_COMPONENT(ext ${f} EXT)
1496 IF(ext STREQUAL .py)
1497 IF(DEST STREQUAL bin/salome)
1499 SET(PERMS ${PERMS} OWNER_READ OWNER_WRITE OWNER_EXECUTE)
1500 SET(PERMS ${PERMS} GROUP_READ GROUP_EXECUTE)
1501 SET(PERMS ${PERMS} WORLD_READ WORLD_EXECUTE)
1502 INSTALL(FILES ${f} DESTINATION ${DEST} PERMISSIONS ${PERMS})
1503 ELSE(DEST STREQUAL bin/salome)
1504 INSTALL(FILES ${f} DESTINATION ${DEST})
1505 ENDIF(DEST STREQUAL bin/salome)
1506 ELSE(ext STREQUAL .py)
1507 INSTALL(FILES ${f} DESTINATION ${DEST})
1508 ENDIF(ext STREQUAL .py)
1511 newlines.append(r'''
1513 GET_FILENAME_COMPONENT(ext ${f} EXT)
1514 IF(ext STREQUAL .qm)
1515 STRING(REGEX REPLACE .qm .ts input ${f})
1517 if self.module in ["kernel", "gui"]:
1518 newlines.append(r'''
1519 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/resources/${input})
1522 newlines.append(r'''
1523 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${input})
1526 newlines.append(r'''
1527 SET(output ${CMAKE_CURRENT_BINARY_DIR}/${f})
1528 # ADD_CUSTOM_COMMAND(
1530 # COMMAND ${QT_LRELEASE_EXECUTABLE} ${input} -qm ${output}
1531 # MAIN_DEPENDENCY ${input}
1533 EXECUTE_PROCESS(COMMAND ${QT_LRELEASE_EXECUTABLE} ${input} -qm ${output})
1534 ENDIF(ext STREQUAL .qm)
1535 INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/${f} DESTINATION ${DEST})
1537 ENDIF(test_SALOMEconfig.h.in)
1539 newlines.append(r'''
1540 GET_FILENAME_COMPONENT(ext ${f} EXT)
1541 IF(ext STREQUAL .py)
1542 INSTALL(CODE "SET(PYTHON_FILE ${f})")
1543 INSTALL(CODE "SET(CMAKE_INSTALL_PREFIX ${CMAKE_INSTALL_PREFIX})")
1544 INSTALL(CODE "SET(DEST ${DEST})")
1545 INSTALL(CODE "SET(PYTHON_EXECUTABLE ${PYTHON_EXECUTABLE})")
1547 if self.module == "kernel":
1549 IF(f STREQUAL SALOME_ContainerPy.py)
1550 ELSE(f STREQUAL SALOME_ContainerPy.py)
1551 IF(f STREQUAL am2cmake.py)
1552 ELSE(f STREQUAL am2cmake.py)
1553 INSTALL(SCRIPT ${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/install_and_compile_python_file.cmake)
1554 ENDIF(f STREQUAL am2cmake.py)
1555 ENDIF(f STREQUAL SALOME_ContainerPy.py)
1559 STRING(REPLACE "\\\\" "/" KERNEL_ROOT_DIR ${KERNEL_ROOT_DIR})
1560 INSTALL(SCRIPT ${KERNEL_ROOT_DIR}/salome_adm/cmake_files/install_and_compile_python_file.cmake)
1563 newlines.append(r'''
1564 ENDIF(ext STREQUAL .py)
1566 newlines.append(r"ENDFOREACH(f ${%s})"%(key))
1569 def writeListsFile(self):
1570 f = open(self.listsFile, "w")
1571 f.write(self.content)
1577 def convertAmFile(the_root, root, dirs, files, f, module):
1578 cmake = CMakeFile(the_root, root, dirs, files, f, module)
1579 cmake.writeListsFile()
1582 def usage(exit_status):
1583 from sys import exit
1584 from sys import argv
1585 print "Usage: %s --module"%(argv[0])
1589 if __name__ == "__main__":
1591 from sys import argv
1597 if module.find('--') != 0:
1601 if len(module) == 0:
1605 from os import getcwd
1609 for root, dirs, files in walk(the_root):
1611 # E.A. : Remove 'CVS' in dirs
1612 # E.A. : It allows to not recurse in CVS dirs
1613 # E.A. : See os module python documentation
1621 if f == "Makefile.am":
1622 convertAmFile(the_root, root, dirs, files, f, module)