1 # -*- coding: iso-8859-1 -*-
2 # Copyright (C) 2007-2010 CEA/DEN, EDF R&D, OPEN CASCADE
4 # This library is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU Lesser General Public
6 # License as published by the Free Software Foundation; either
7 # version 2.1 of the License.
9 # This library is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 # Lesser General Public License for more details.
14 # You should have received a copy of the GNU Lesser General Public
15 # License along with this library; if not, write to the Free Software
16 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
24 # A set of regular expressions used ...
27 p_multiline = re.compile(r"""
33 p_dollar = re.compile(r"""
35 (?P<val> # open the group val
36 [^)]* # the group contain 0 or more non ) characters
41 p_arobas = re.compile(r"""
43 (?P<val> # open the group val
44 [^@]* # the group contain 0 or more non @ characters
49 p_if = re.compile(r"""
50 ^ # beginning of the string
54 (?P<val> # open the group val
55 .+ # the group contain 1 or more non space characters
59 p_else = re.compile(r"""
60 ^ # beginning of the line
66 p_endif = re.compile(r"""
67 ^ # beginning of the line
73 p_attribution = re.compile(r"""
74 ^ # beginning of the line
75 (?P<spaces> # open the group spaces
78 (?P<key> # open the group key
79 \w+ # the group contain 1 or more alphanumeric characters
82 (?P<method> # open the group method
86 (?P<value> # open the group value
87 .* # 0 or more any characters
93 class CMakeFile(object):
95 def __init__(self, the_root, root, dirs, files, f, module):
97 self.the_root = the_root
103 from os.path import join
104 self.amFile = join(root, f)
105 self.listsFile = join(root, "CMakeLists.txt")
114 # Read the Makefile.am file
117 stream = open(amFile)
118 content = stream.read()
122 # Replace the composed lines separated by "\\n" by an unique line
124 content = p_multiline.sub(r' ', content)
127 # Compatibility netgen plugin
129 content = content.replace("../NETGEN/libNETGEN.la", "${NETGEN_LIBS}")
204 "vtkGraphicsPythonD",
211 "LifeCycleCORBATest",
218 "SalomeCommunication",
221 "SalomeDSCContainer",
223 "SalomeDSCSupervBasic",
233 "SalomeLifeCycleCORBA",
235 "SALOMELocalTraceTest",
236 "SalomeLoggerServer",
237 "SalomeMPIContainer",
238 "SalomeNotification",
240 "SalomeResourcesManager",
241 "SalomeTestComponentEngine",
242 "SalomeTestMPIComponentEngine",
243 "SALOMETraceCollectorTest",
246 "with_loggerTraceCollector",
271 "SalomePyQtGUILight",
306 "GEOMFiltersSelection",
337 "medcouplingremapper",
352 "paramedcouplingcorba",
361 "GeomSelectionTools",
374 "SMESHFiltersSelection",
382 full_list = cas_list + vtk_list
383 full_list += kernel_list + gui_list
384 full_list += geom_list + med_list + smesh_list
386 # E.A. : sort by len before substitution ...
387 # Why ? Thing to "-lMEDWrapper" then "-lMEDWrapper_V2_1" substition
388 # And you understand ...
390 full_list.sort(cmp = lambda x, y : cmp(len(y), len(x)))
392 for key in full_list:
393 content = content.replace("-l%s"%(key), "${%s}"%(key))
397 # Split content in lines to treat each one separately
399 lines = content.split('\n')
402 # newlines contains the lines of the future CMakeLists.txt file
407 # opened_ifs is used to deals with nested conditionnals
412 # the __thedict__ dictionnary contains key, val
413 # of the Makefile.am file
415 self.__thedict__ = {}
418 # Initialize file ... mainly includes other cmake files
420 self.initialize(newlines)
423 # Do the job for each line
426 self.treatLine(line, newlines, opened_ifs)
430 # Finalize file ... it is in here the cmake job is done
432 self.finalize(newlines)
435 # Concatenate newlines into content
437 content = '\n'.join(newlines)
440 # Add a CR at end if necessary
442 lines = content.split('\n')
443 # lines = [ l.strip() for l in lines ]
444 if len(lines[-1]) != 0:
447 content = '\n'.join(lines)
450 self.content = content
455 def initialize(self, newlines):
456 if self.root == self.the_root:
459 CMAKE_MINIMUM_REQUIRED(VERSION 2.4.7 FATAL_ERROR)
460 IF(COMMAND cmake_policy)
461 cmake_policy(SET CMP0003 NEW)
462 ENDIF(COMMAND cmake_policy)
471 """%(self.module.upper()))
473 if self.module == "kernel":
475 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindPLATFORM.cmake)
476 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindPYTHON.cmake)
477 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindOMNIORB.cmake)
478 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindPTHREADS.cmake)
479 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindHDF5.cmake)
480 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindBOOST.cmake)
481 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindLIBXML2.cmake)
482 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindSWIG.cmake)
483 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindCPPUNIT.cmake)
484 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindDOXYGEN.cmake)
485 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindMPI.cmake)
486 INCLUDE(${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/FindLIBBATCH.cmake)
490 if self.module == "med":
492 SET(KERNEL_ROOT_DIR $ENV{KERNEL_ROOT_DIR})
494 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindPLATFORM.cmake)
495 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindPYTHON.cmake)
496 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindOMNIORB.cmake)
497 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindPTHREADS.cmake)
498 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindHDF5.cmake)
499 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindBOOST.cmake)
500 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindLIBXML2.cmake)
501 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindSWIG.cmake)
502 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindCPPUNIT.cmake)
503 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindDOXYGEN.cmake)
504 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindMPI.cmake)
505 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindLIBBATCH.cmake)
506 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindKERNEL.cmake)
507 ELSE(KERNEL_ROOT_DIR)
508 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local_without_kernel/cmake_files/FindPLATFORM.cmake)
509 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local_without_kernel/cmake_files/FindMPI.cmake)
510 ENDIF(KERNEL_ROOT_DIR)
514 SET(KERNEL_ROOT_DIR $ENV{KERNEL_ROOT_DIR})
515 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindPLATFORM.cmake)
516 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindPYTHON.cmake)
517 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindOMNIORB.cmake)
518 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindPTHREADS.cmake)
519 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindHDF5.cmake)
520 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindBOOST.cmake)
521 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindLIBXML2.cmake)
522 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindSWIG.cmake)
523 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindCPPUNIT.cmake)
524 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindDOXYGEN.cmake)
525 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindMPI.cmake)
526 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindLIBBATCH.cmake)
527 INCLUDE(${KERNEL_ROOT_DIR}/salome_adm/cmake_files/FindKERNEL.cmake)
530 if self.module == "gui":
532 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindCAS.cmake)
533 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindQT4.cmake)
534 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindOPENGL.cmake)
535 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindVTK.cmake)
536 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindQWT.cmake)
537 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindSIPPYQT.cmake)
541 SET(GUI_ROOT_DIR $ENV{GUI_ROOT_DIR})
543 INCLUDE(${GUI_ROOT_DIR}/adm_local/cmake_files/FindCAS.cmake)
544 INCLUDE(${GUI_ROOT_DIR}/adm_local/cmake_files/FindQT4.cmake)
545 INCLUDE(${GUI_ROOT_DIR}/adm_local/cmake_files/FindOPENGL.cmake)
546 INCLUDE(${GUI_ROOT_DIR}/adm_local/cmake_files/FindVTK.cmake)
547 INCLUDE(${GUI_ROOT_DIR}/adm_local/cmake_files/FindQWT.cmake)
548 INCLUDE(${GUI_ROOT_DIR}/adm_local/cmake_files/FindSIPPYQT.cmake)
549 INCLUDE(${GUI_ROOT_DIR}/adm_local/cmake_files/FindGUI.cmake)
552 if self.module == "med":
554 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindMEDFILE.cmake)
556 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindXDR.cmake)
560 if self.module == "smesh":
562 SET(GEOM_ROOT_DIR $ENV{GEOM_ROOT_DIR})
563 SET(MED_ROOT_DIR $ENV{MED_ROOT_DIR})
564 INCLUDE(${GEOM_ROOT_DIR}/adm_local/cmake_files/FindGEOM.cmake)
565 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMEDFILE.cmake)
566 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMED.cmake)
569 if self.module == "netgenplugin":
571 SET(GEOM_ROOT_DIR $ENV{GEOM_ROOT_DIR})
572 SET(MED_ROOT_DIR $ENV{MED_ROOT_DIR})
573 SET(SMESH_ROOT_DIR $ENV{SMESH_ROOT_DIR})
574 INCLUDE(${GEOM_ROOT_DIR}/adm_local/cmake_files/FindGEOM.cmake)
575 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMED.cmake)
576 INCLUDE(${SMESH_ROOT_DIR}/adm_local/cmake_files/FindSMESH.cmake)
577 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindNETGEN.cmake)
580 if self.module == "blsurfplugin":
582 SET(GEOM_ROOT_DIR $ENV{GEOM_ROOT_DIR})
583 SET(MED_ROOT_DIR $ENV{MED_ROOT_DIR})
584 SET(SMESH_ROOT_DIR $ENV{SMESH_ROOT_DIR})
585 INCLUDE(${GEOM_ROOT_DIR}/adm_local/cmake_files/FindGEOM.cmake)
586 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMED.cmake)
587 INCLUDE(${SMESH_ROOT_DIR}/adm_local/cmake_files/FindSMESH.cmake)
588 INCLUDE(${CMAKE_SOURCE_DIR}/adm_local/cmake_files/FindBLSURF.cmake)
591 if self.module in ["ghs3dplugin", "hexoticplugin"]:
593 SET(GEOM_ROOT_DIR $ENV{GEOM_ROOT_DIR})
594 SET(MED_ROOT_DIR $ENV{MED_ROOT_DIR})
595 SET(SMESH_ROOT_DIR $ENV{SMESH_ROOT_DIR})
596 INCLUDE(${GEOM_ROOT_DIR}/adm_local/cmake_files/FindGEOM.cmake)
597 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMED.cmake)
598 INCLUDE(${SMESH_ROOT_DIR}/adm_local/cmake_files/FindSMESH.cmake)
601 if self.module == "ghs3dprlplugin":
603 SET(GEOM_ROOT_DIR $ENV{GEOM_ROOT_DIR})
604 SET(MED_ROOT_DIR $ENV{MED_ROOT_DIR})
605 SET(SMESH_ROOT_DIR $ENV{SMESH_ROOT_DIR})
606 INCLUDE(${GEOM_ROOT_DIR}/adm_local/cmake_files/FindGEOM.cmake)
607 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMEDFILE.cmake)
608 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMED.cmake)
609 INCLUDE(${SMESH_ROOT_DIR}/adm_local/cmake_files/FindSMESH.cmake)
612 if self.module == "visu":
614 SET(MED_ROOT_DIR $ENV{MED_ROOT_DIR})
615 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMED.cmake)
618 if self.module == "yacs":
620 INCLUDE(${CMAKE_SOURCE_DIR}/adm/cmake/FindEXPAT.cmake)
621 INCLUDE(${CMAKE_SOURCE_DIR}/adm/cmake/FindGRAPHVIZ.cmake)
624 if self.module == "hxx2salome":
626 SET(MED_ROOT_DIR $ENV{MED_ROOT_DIR})
627 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMEDFILE.cmake)
628 INCLUDE(${MED_ROOT_DIR}/adm_local/cmake_files/FindMED.cmake)
637 if self.module not in ['med']:
645 if self.module == "kernel":
649 SET(CALCIUM_IDL_INT_F77 long)
650 SET(CALCIUM_CORBA_INT_F77 CORBA::Long)
653 elif self.module == "gui":
655 SET(GUI_ENABLE_CORBA ${CORBA_GEN})
656 SET(ENABLE_VTKVIEWER ON)
657 SET(ENABLE_SALOMEOBJECT ON)
658 SET(ENABLE_OCCVIEWER ON)
659 SET(ENABLE_GLVIEWER ON)
660 SET(ENABLE_PLOT2DVIEWER ON)
661 SET(ENABLE_PYCONSOLE ON)
662 SET(ENABLE_SUPERVGRAPHVIEWER ON)
663 SET(ENABLE_QXGRAPHVIEWER ON)
666 elif self.module == "jobmanager":
673 elif self.module == "geom":
676 SET(GEOM_ENABLE_GUI ON)
680 elif self.module == "medfile":
682 SET(MED_NUM_MAJEUR 2)
683 SET(MED_NUM_MINEUR 3)
684 SET(MED_NUM_RELEASE 5)
687 SET(FLIBS -lgfortranbegin -lgfortran)
691 elif self.module == "med":
694 SET(MED_ENABLE_KERNEL ON)
696 SET(MED_ENABLE_SPLITTER ON)
698 ENDIF(KERNEL_ROOT_DIR)
700 SET(MED_ENABLE_GUI ON)
704 elif self.module == "smesh":
707 SET(SMESH_ENABLE_GUI ON)
711 elif self.module == "netgen":
713 SET(OCCFLAGS ${CAS_CPPFLAGS})
714 SET(OCCLIBS ${CAS_LDPATH})
715 SET(OCCLIBS ${OCCLIBS} ${TKernel} ${TKGeomBase} ${TKMath} ${TKG2d} ${TKG3d} ${TKXSBase} ${TKOffset} ${TKFillet} ${TKShHealing})
716 SET(OCCLIBS ${OCCLIBS} ${TKMesh} ${TKMeshVS} ${TKTopAlgo} ${TKGeomAlgo} ${TKBool} ${TKPrim} ${TKBO} ${TKIGES} ${TKBRep})
717 SET(OCCLIBS ${OCCLIBS} ${TKSTEPBase} ${TKSTEP} ${TKSTL} ${TKSTEPAttr} ${TKSTEP209} ${TKXDESTEP} ${TKXDEIGES} ${TKXCAF} ${TKLCAF} ${FWOSPlugin})
720 elif self.module == "netgenplugin":
723 SET(NETGENPLUGIN_ENABLE_GUI ON)
727 elif self.module == "blsurfplugin":
730 SET(BLSURFPLUGIN_ENABLE_GUI ON)
734 elif self.module == "ghs3dplugin":
737 SET(GHS3DPLUGIN_ENABLE_GUI ON)
741 elif self.module == "hexoticplugin":
744 SET(HEXOTICPLUGIN_ENABLE_GUI ON)
748 elif self.module == "ghs3dprlplugin":
751 SET(GHS3DPRLPLUGIN_ENABLE_GUI ON)
755 elif self.module == "yacs":
757 SET(SALOME_KERNEL ON)
765 set(XVERSION 0x060300)
770 SET(VERSION_INFO 0.0.0)
771 SET(SOVERSION_INFO 0)
776 SET(pythondir lib/python${PYTHON_VERSION}/site-packages)
777 SET(salomepythondir ${pythondir}/salome)
778 SET(salomepypkgdir ${salomepythondir}/salome)
780 if self.module == "netgen":
782 SET(AM_CXXFLAGS ${AM_CXXFLAGS} -DNO_PARALLEL_THREADS -DOCCGEOMETRY -I${CMAKE_BINARY_DIR} -I${CMAKE_CURRENT_SOURCE_DIR})
784 elif self.module == "kernel":
786 SET(AM_CPPFLAGS ${AM_CPPFLAGS} -DHAVE_SALOME_CONFIG -I${CMAKE_BINARY_DIR}/salome_adm/unix -include SALOMEconfig.h)
787 SET(AM_CXXFLAGS ${AM_CXXFLAGS} -DHAVE_SALOME_CONFIG -I${CMAKE_BINARY_DIR}/salome_adm/unix -include SALOMEconfig.h)
790 if self.module not in ["yacs"]:
793 SET(AM_CPPFLAGS ${AM_CPPFLAGS} -DHAVE_SALOME_CONFIG -I${KERNEL_ROOT_DIR}/include/salome -include SALOMEconfig.h)
794 SET(AM_CXXFLAGS ${AM_CXXFLAGS} -DHAVE_SALOME_CONFIG -I${KERNEL_ROOT_DIR}/include/salome -include SALOMEconfig.h)
795 ENDIF(KERNEL_ROOT_DIR)
798 if self.module == "gui":
801 SET(AM_CPPFLAGS ${AM_CPPFLAGS} -DWITH_SALOMEDS_OBSERVER)
802 SET(AM_CXXFLAGS ${AM_CXXFLAGS} -DWITH_SALOMEDS_OBSERVER)
803 ENDIF(KERNEL_ROOT_DIR)
806 if self.module == "hxx2salome":
808 if self.the_root[-len(key):] != key:
809 msg = "Source dir must finished with %s !"%(key)
811 hxxmodule = self.the_root[:-len(key)]
812 from os.path import basename
813 hxxmodule = basename(hxxmodule)
814 hxxmodule = hxxmodule.lower()
815 self.hxxmodule = hxxmodule
817 SET(HXXCPP_ROOT_DIR $ENV{%sCPP_ROOT_DIR})
818 SET(AM_CPPFLAGS ${AM_CPPFLAGS} -I${HXXCPP_ROOT_DIR}/include)
819 SET(AM_CXXFLAGS ${AM_CXXFLAGS} -I${HXXCPP_ROOT_DIR}/include)
820 SET(LDADD ${LDADD} -L${HXXCPP_ROOT_DIR}/lib)
821 '''%(hxxmodule.upper()))
827 def treatLine(self, line, newlines, opened_ifs):
830 # Print the comment above the line itself
832 if line.find('#') >= 0:
833 fields = line.split('#')
835 comment = '#'.join([''] + fields[1:])
836 newlines.append(comment)
842 # If the line begins with 'include ', just comment it
844 if line.find("include ") == 0:
845 newlines.append("# " + line)
849 # If the line begins with '-include', just comment it
851 if line.find("-include") == 0:
852 newlines.append("# " + line)
856 # If the line is a definition of a make rule, just comment it
858 if line.count(':') == 1:
859 newlines.append("# " + line)
863 # A particuliar case where there are two ":" on the same line
865 if line.find('install-exec-local:') == 0:
866 newlines.append("# " + line)
870 # If the line begin by a tabulation, consider it's a makefile command and comment it
872 if line.find("\t") == 0:
873 newlines.append("# " + line)
878 key = "-version-info"
879 if line.find(key) >= 0:
881 before = line.split(key)[0]
882 after = line[len(before)+len(key):]
885 version_info = after.split()[0]
886 line = line.replace(key+sep+version_info, "")
888 version_info = version_info.replace(':', '.')
889 soversion_info = version_info.split('.')[0]
890 newlines.append("SET(VERSION_INFO " + version_info + ")")
891 newlines.append("SET(SOVERSION_INFO " + soversion_info + ")")
896 # Replace the $(TOTO) by ${TOTO}
897 # Replace the @TOTO@ by ${TOTO}
899 line = p_dollar.sub(r"${\1}", line)
900 line = p_arobas.sub(r"${\1}", line)
903 line = line.replace(r"${top_builddir}", r"${CMAKE_BINARY_DIR}")
904 line = line.replace(r"${top_srcdir}", r"${CMAKE_SOURCE_DIR}")
905 line = line.replace(r"${srcdir}", r"${CMAKE_CURRENT_SOURCE_DIR}")
906 line = line.replace(r"${builddir}", r"${CMAKE_CURRENT_BINARY_DIR}")
907 line = line.replace(r"${datadir}", r"${CMAKE_INSTALL_PREFIX}/share")
910 # Check if the line is a 'if' condition
911 # If yes, replace it by a cmake grammar
913 match = p_if.match(line)
915 theif = match.group("val")
917 theif = "NOT " + theif[1:]
919 line = p_if.sub(r"IF(%s)"%(theif), line)
920 opened_ifs.append(theif)
921 newlines.append(line)
925 # Check if the line is a 'else' condition
926 # If yes, replace it by a cmake grammar
928 match = p_else.match(line)
930 line = "ELSE(%s)"%(opened_ifs[-1])
931 newlines.append(line)
935 # Check if the line is a 'endif' condition
936 # If yes, replace it by a cmake grammar
938 match = p_endif.match(line)
940 line = "ENDIF(%s)"%(opened_ifs[-1])
942 newlines.append(line)
946 # Check if the line is an attribution '=' or '+='
948 match = p_attribution.match(line)
950 self.treatAttribution(match, newlines)
954 newlines.append(line)
959 def treatAttribution(self, match, newlines):
961 spaces = match.group("spaces")
962 key = match.group("key")
963 method = match.group("method")
964 value = match.group("value")
965 # print [spaces, key, method, value]
968 # Open cmake SET command
970 newlines.append(spaces + "SET(" + key)
973 # If method is '+=', put the previous definition as first value
976 newlines.append("%s ${%s}"%(spaces, key))
980 fields = value.split()
981 for i in range(len(fields)):
982 newlines.append("%s %s"%(spaces, fields[i]))
988 # The try: except KeyError is here if the +=
989 # is an error which occurs in salome ...
992 self.__thedict__[key] += fields[:]
994 self.__thedict__[key] = fields[:]
998 self.__thedict__[key] = fields[:]
1002 # Close cmake SET command
1005 newlines.append("%s)"%(spaces))
1009 def finalize(self, newlines):
1012 # Convert the .in files in build dir
1017 if mod in ['kernel', 'gui'] and self.root[-len('gui'):] == 'gui' or mod == 'med' and operator.contains(self.root, 'doxygen'):
1018 newlines.append(r'''
1026 ${CMAKE_CURRENT_SOURCE_DIR}
1029 ${CMAKE_CURRENT_BINARY_DIR}
1032 ${CMAKE_INSTALL_PREFIX}/share
1035 ${datadir}/doc/salome
1038 self.files.append("static/header.html.in")
1039 elif self.root[-len(mod):] == mod.upper() and operator.contains(self.root, 'doc') or mod in ['kernel', 'gui', 'geom', 'med', 'smesh', 'visu'] and self.root[-len('tui'):] == 'tui':
1040 newlines.append(r'''
1048 ${CMAKE_CURRENT_SOURCE_DIR}
1051 ${CMAKE_CURRENT_BINARY_DIR}
1054 ${CMAKE_INSTALL_PREFIX}/share
1057 ${datadir}/doc/salome
1060 self.files.append("static/header.html.in")
1061 if self.module == "yacs":
1063 if self.root[-len(key):] == key:
1064 self.files.append("resources/YACSCatalog.xml.in")
1067 for f in self.files:
1069 if self.module == 'yacs' and f == "Doxyfile.in":
1071 if f == "sstream.in":
1073 if f in ["runContainer.in", "stopContainer.in"]:
1074 if self.module == "med":
1075 if self.root[-3:] == "csh":
1079 if f == "SALOMEconfig.ref.in":
1080 out = "SALOMEconfig.h"
1084 newlines.append(r'''
1085 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/%s)
1087 newlines.append(r'''
1088 SET(output ${CMAKE_CURRENT_BINARY_DIR}/%s)
1090 newlines.append(r'''
1091 MESSAGE(STATUS "Creation of ${output}")
1092 CONFIGURE_FILE(${input} ${output})
1098 # add commands for generating of user's documentation
1101 upmod = self.module.upper()
1102 doc_gui_destination = "${CMAKE_INSTALL_PREFIX}/share/doc/salome/gui/%s"%(upmod)
1103 doc_tui_destination = "${CMAKE_INSTALL_PREFIX}/share/doc/salome/tui/%s"%(upmod)
1104 doc_destination = "${CMAKE_INSTALL_PREFIX}/share/doc/salome"
1105 head_source = "${CMAKE_CURRENT_SOURCE_DIR}/images/head.png"
1107 copytree_src = "${CMAKE_SOURCE_DIR}/salome_adm/cmake_files"
1109 copytree_src = "$ENV{KERNEL_ROOT_DIR}/salome_adm/cmake_files"
1110 str = "import re \nimport sys \noutfile = open(sys.argv[1], 'wb') \nfor line in open(sys.argv[2], 'rb').readlines():"
1111 str += "\n if re.match('class '+sys.argv[3]+'DC', line): \n continue \n line = re.sub(r'^\s+\#', '#', line) \n line = re.sub(r'^\s+def', 'def', line) \n line = re.sub(sys.argv[3]+'DC', sys.argv[3], line)"
1112 str += "\n outfile.write(line) \noutfile.close()"
1114 if mod in ['kernel', 'gui'] and self.root[-len('gui'):] == 'gui' or mod == 'med' and operator.contains(self.root, 'doxygen'):
1116 doc_source = "${CMAKE_CURRENT_BINARY_DIR}/doc_ref_user/html"
1117 input = "Doxyfile_med_user"
1119 doc_source = "${CMAKE_CURRENT_BINARY_DIR}/%s"%(upmod)
1121 newlines.append("""\t ADD_CUSTOM_TARGET(usr_docs ${DOXYGEN_EXECUTABLE} %s
1122 COMMAND ${PYTHON_EXECUTABLE} -c "import shutil, sys; sys.path.append(r'''%s'''); shutil.rmtree(r'''%s''', True); import copytree1; copytree1.copytree(r'''%s''', r'''%s'''); shutil.copy(r'''%s''', r'''%s''')"
1124 WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
1125 )"""%(input, copytree_src, doc_gui_destination, doc_source, doc_gui_destination, head_source, doc_gui_destination))
1127 if mod in ['geom', 'smesh', 'visu'] and self.root[-len(mod):] == upmod and operator.contains(self.root, 'doc'):
1128 ign = r"""'tempfile', '*usr_docs*', '*CMakeFiles*', '*.cmake', 'doxyfile*', '*.vcproj', 'static', 'Makefile*'"""
1129 if mod in ['geom', 'smesh']:
1132 input = "COMMAND ${DOXYGEN_EXECUTABLE} doxyfile_tui \n\t\t"
1136 newlines.append(r"""
1137 FILE(WRITE ${CMAKE_CURRENT_BINARY_DIR}/tempfile "%s")
1138 ADD_CUSTOM_TARGET(usr_docs ${PYTHON_EXECUTABLE} tempfile ${CMAKE_BINARY_DIR}/src/%s_SWIG/%s.py ${CMAKE_SOURCE_DIR}/src/%s_SWIG/%sDC.py %s
1139 %sCOMMAND ${DOXYGEN_EXECUTABLE} doxyfile_py
1140 COMMAND ${DOXYGEN_EXECUTABLE} doxyfile
1141 COMMAND ${PYTHON_EXECUTABLE} -c "import os; os.remove(r'''${CMAKE_BINARY_DIR}/src/%s_SWIG/%s.py''')"
1142 COMMAND ${PYTHON_EXECUTABLE} -c "import shutil, sys; sys.path.append(r'''%s'''); shutil.rmtree(r'''%s''', True); import copytree1; copytree1.copytree(r'''${CMAKE_CURRENT_BINARY_DIR}''', r'''%s''', ignore=copytree1.ignore_patterns(%s)); shutil.copy(r'''%s''', r'''%s''')"
1144 WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
1145 )"""%(str, upmod, tmp, upmod, tmp, tmp, input, upmod, tmp, copytree_src, doc_gui_destination, doc_gui_destination, ign, head_source, doc_gui_destination))
1147 newlines.append("""\t ADD_CUSTOM_TARGET(usr_docs ${DOXYGEN_EXECUTABLE} doxyfile_idl
1148 COMMAND ${DOXYGEN_EXECUTABLE} doxyfile
1149 COMMAND ${PYTHON_EXECUTABLE} -c "import shutil, sys; sys.path.append(r'''%s'''); shutil.rmtree(r'''%s''',True); import copytree1; copytree1.copytree(r'''${CMAKE_CURRENT_BINARY_DIR}''',r'''%s''', ignore=copytree1.ignore_patterns(%s)); shutil.copy(r'''%s''',r'''%s''')"
1151 WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
1152 )"""%(copytree_src, doc_gui_destination, doc_gui_destination, ign, head_source, doc_gui_destination))
1155 # add commands for generating of developer's documentation
1158 upmod = self.module.upper()
1159 if mod in ['kernel', 'gui', 'med', 'smesh', 'visu'] and self.root[-len('tui'):] == 'tui':
1161 tmp = """\tADD_CUSTOM_TARGET(dev_docs ${DOXYGEN_EXECUTABLE} -u
1162 COMMAND ${DOXYGEN_EXECUTABLE}
1163 COMMAND ${PYTHON_EXECUTABLE} -c "import os; os.remove(r'''${CMAKE_CURRENT_BINARY_DIR}/doxyfile.bak''')" """
1166 tmp = """\tADD_CUSTOM_TARGET(dev_docs ${DOXYGEN_EXECUTABLE}"""
1168 tmp1= r"""\n COMMAND ${PYTHON_EXECUTABLE} -c "from shutil import copy; copy(r'''${CMAKE_CURRENT_SOURCE_DIR}/images/visuscreen.png''', r'''%s''')" """%(doc_tui_destination)
1169 elif mod == 'smesh':
1170 extra_srcdir = "${CMAKE_CURRENT_SOURCE_DIR}/extra"
1171 tmp1= """\n COMMAND ${PYTHON_EXECUTABLE} -c "from shutil import copy; copy(r'''${CMAKE_CURRENT_SOURCE_DIR}/images/smeshscreen.png''', r'''%s'''); copy(r'''%s/AddNetgenInSalome2.pdf''', r'''%s'''); copy(r'''%s/PluginMeshers.html''', r'''%s''')"
1172 COMMAND ${PYTHON_EXECUTABLE} -c "from shutil import copy; copy(r'''%s/AddNetgenInSalome2.ps''', r'''%s'''); copy(r'''%s/AddNetgenInSalome2.sxw''', r'''%s''')" """%(doc_tui_destination, extra_srcdir,doc_destination, extra_srcdir,doc_destination, extra_srcdir,doc_destination,extra_srcdir,doc_destination)
1175 doc_source = "${CMAKE_CURRENT_BINARY_DIR}/%s"%(upmod)
1176 newlines.append(tmp + """
1177 COMMAND ${PYTHON_EXECUTABLE} -c "import shutil, sys; sys.path.append(r'''%s'''); shutil.rmtree(r'''%s''', True); import copytree1; copytree1.copytree(r'''%s''', r'''%s'''); shutil.copy(r'''%s''', r'''%s''')" """%(copytree_src, doc_tui_destination, doc_source, doc_tui_destination, head_source, doc_tui_destination) + tmp1 + """
1179 WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
1181 if mod == 'geom' and self.root[-len('tui'):] == 'tui':
1183 doc_source = "${CMAKE_CURRENT_BINARY_DIR}/%s"%(upmod)
1184 newlines.append(r"""
1185 FILE(WRITE ${CMAKE_CURRENT_BINARY_DIR}/tempfile "%s")
1186 ADD_CUSTOM_TARGET(dev_docs ${PYTHON_EXECUTABLE} tempfile ${CMAKE_BINARY_DIR}/src/%s_SWIG/%s.py ${CMAKE_SOURCE_DIR}/src/%s_SWIG/%sDC.py %s
1187 COMMAND ${DOXYGEN_EXECUTABLE} doxyfile
1188 COMMAND ${PYTHON_EXECUTABLE} -c "import os; os.remove(r'''${CMAKE_BINARY_DIR}/src/%s_SWIG/%s.py''')"
1189 COMMAND ${PYTHON_EXECUTABLE} -c "import shutil, sys; sys.path.append(r'''%s'''); shutil.rmtree(r'''%s''', True); import copytree1; copytree1.copytree(r'''%s''', r'''%s'''); shutil.copy(r'''%s''', r'''%s'''); shutil.copy(r'''${CMAKE_CURRENT_SOURCE_DIR}/images/geomscreen.png''', r'''%s''')"
1191 WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
1192 )"""%(str, upmod, tmp, upmod, tmp, tmp, upmod, tmp, copytree_src, doc_tui_destination, doc_source, doc_tui_destination, head_source, doc_tui_destination, doc_tui_destination))
1195 # convert the SUBDIRS in cmake grammar
1197 if 1: # self.__thedict__.has_key("SUBDIRS"):
1198 newlines.append(r'''
1199 FOREACH(dir ${SUBDIRS})
1200 IF(NOT dir STREQUAL .)
1201 ADD_SUBDIRECTORY(${dir})
1202 ENDIF(NOT dir STREQUAL .)
1203 ENDFOREACH(dir ${SUBDIRS})
1209 for key in ["lib_LTLIBRARIES", "noinst_LTLIBRARIES", "salomepyexec_LTLIBRARIES"]:
1210 if self.__thedict__.has_key(key):
1211 self.addLibTarget(key, newlines)
1217 for key in ["bin_PROGRAMS", "check_PROGRAMS"]:
1218 if self.__thedict__.has_key(key):
1219 self.addBinTarget(key, newlines)
1225 if self.__thedict__.has_key("BASEIDL_FILES"):
1226 if not self.__thedict__.has_key("IDL_FILES"):
1227 self.__thedict__["IDL_FILES"] = self.__thedict__["BASEIDL_FILES"]
1229 SET(IDL_FILES ${BASEIDL_FILES})
1238 if self.__thedict__.has_key(key):
1239 if self.module == "kernel":
1241 SET(IDL_FILES ${IDL_FILES} Calcium_Ports.idl)
1245 FOREACH(input ${IDL_FILES})
1246 STRING(REGEX REPLACE ".idl" "" base ${input})
1247 SET(src ${CMAKE_CURRENT_BINARY_DIR}/${base}SK.cc)
1249 SET(dynsrc ${CMAKE_CURRENT_BINARY_DIR}/${base}DynSK.cc)
1250 SET(outputs ${outputs} ${dynsrc})
1251 SET(inc ${CMAKE_CURRENT_BINARY_DIR}/${base}.hh)
1252 SET(outputs ${outputs} ${inc})
1253 IF(input STREQUAL Calcium_Ports.idl)
1254 SET(input ${CMAKE_CURRENT_BINARY_DIR}/${input})
1255 ELSE(input STREQUAL Calcium_Ports.idl)
1256 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${input})
1257 ENDIF(input STREQUAL Calcium_Ports.idl)
1258 SET(flags ${IDLCXXFLAGS} ${OMNIORB_IDLCXXFLAGS})
1259 STRING(REGEX MATCH "-bcxx" ISBCXX ${flags})
1261 SET(flags -bcxx ${flags})
1265 COMMAND ${OMNIORB_IDL} ${flags} ${input}
1266 MAIN_DEPENDENCY ${input}
1270 install(FILES ${input} DESTINATION idl/salome)
1272 if self.module not in ["pyhello"]:
1274 SET(IDL_HEADER ${CMAKE_CURRENT_BINARY_DIR}/${base}.hh)
1275 install(FILES ${IDL_HEADER} DESTINATION include/salome)
1279 INSTALL(CODE "SET(IDL_FILE ${input})")
1280 INSTALL(CODE "SET(DIR ${salomepythondir})")
1282 INSTALL(CODE "SET(DIR bin/salome)")
1284 INSTALL(CODE "SET(CMAKE_CURRENT_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR})")
1285 INSTALL(CODE "SET(OMNIORB_IDL_PYTHON ${OMNIORB_IDL_PYTHON})")
1288 FOREACH(f ${IDLPYFLAGS})
1289 SET(flags "${flags} ${f}")
1290 ENDFOREACH(f ${IDLPYFLAGS})
1291 STRING(REGEX MATCH "-bpython" ISBPYTHON ${flags})
1293 SET(flags "-bpython ${flags}")
1294 ENDIF(NOT ISBPYTHON)
1295 SET(IDLPYFLAGS ${flags})
1296 STRING(REPLACE "\\\\" "/" IDLPYFLAGS ${IDLPYFLAGS})
1297 INSTALL(CODE "SET(IDLPYFLAGS ${IDLPYFLAGS})")
1300 if self.module == "kernel":
1302 INSTALL(SCRIPT ${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/install_python_from_idl.cmake)
1306 STRING(REPLACE "\\\\" "/" KERNEL_ROOT_DIR ${KERNEL_ROOT_DIR})
1307 INSTALL(SCRIPT ${KERNEL_ROOT_DIR}/salome_adm/cmake_files/install_python_from_idl.cmake)
1311 ENDFOREACH(input ${IDL_FILES})
1317 for key in ["SWIG_SRC", "SWIGSOURCES", "SWIG_DEF"]:
1318 if self.__thedict__.has_key(key):
1320 SET(SWIG_SOURCES ${%s})
1322 self.__thedict__["SWIG_SOURCES"] = self.__thedict__[key]
1328 if self.__thedict__.has_key("SWIG_SOURCES"):
1330 IF(SWIG_SOURCES MATCHES ";")
1331 STRING(REGEX REPLACE ";.*" "" SWIG_SOURCES_FIRST "${SWIG_SOURCES}")
1332 ELSE(SWIG_SOURCES MATCHES ";")
1333 SET(SWIG_SOURCES_FIRST "${SWIG_SOURCES}")
1334 ENDIF(SWIG_SOURCES MATCHES ";")
1336 FOREACH(f ${SWIG_FLAGS} ${MY_SWIG_FLAGS})
1339 LIST(FIND flags ${f} index)
1340 IF(NOT index EQUAL -1)
1342 ENDIF(NOT index EQUAL -1)
1345 SET(flags ${flags} ${f})
1347 ENDFOREACH(f ${SWIG_FLAGS} ${MY_SWIG_FLAGS})
1349 OUTPUT ${build_srcs}
1350 COMMAND ${SWIG_EXECUTABLE} ${flags} -o ${build_srcs} ${CMAKE_CURRENT_SOURCE_DIR}/${SWIG_SOURCES_FIRST}
1351 MAIN_DEPENDENCY ${SWIG_SOURCES}
1358 if self.__thedict__.has_key("BUILT_SOURCES"):
1360 FOREACH(f ${BUILT_SOURCES})
1361 IF(f MATCHES "WRAP.cxx$")
1362 # STRING(REGEX REPLACE "WRAP.cxx" "WRAP.h" inc ${f})
1363 STRING(REGEX REPLACE "WRAP.cxx" ".i" input ${f})
1365 OUTPUT ${f} # ${inc}
1366 COMMAND ${SWIG_EXECUTABLE} ${SWIG_FLAGS} ${SWIG_PYTHON_INCLUDES} ${MYSWIG_FLAGS} -o ${f} ${CMAKE_CURRENT_SOURCE_DIR}/${input}
1367 MAIN_DEPENDENCY ${CMAKE_CURRENT_SOURCE_DIR}/${input}
1369 ENDIF(f MATCHES "WRAP.cxx$")
1370 ENDFOREACH(f ${BUILT_SOURCES})
1377 if self.__thedict__.has_key(key):
1379 FOREACH(output ${MOC_FILES})
1381 if self.module in ["jobmanager", "yacs"]:
1383 STRING(REGEX REPLACE _moc.cxx .hxx input ${output})
1387 STRING(REGEX REPLACE _moc.cxx .h input ${output})
1391 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${input})
1392 SET(output ${CMAKE_CURRENT_BINARY_DIR}/${output})
1395 COMMAND ${QT_MOC_EXECUTABLE} ${MOC_FLAGS} ${input} -o ${output}
1396 MAIN_DEPENDENCY ${input}
1398 ENDFOREACH(output ${MOC_FILES})
1405 if self.__thedict__.has_key(key):
1407 FOREACH(output ${UIC_FILES})
1408 STRING(REPLACE "ui_" "" input ${output})
1409 STRING(REPLACE ".h" ".ui" input ${input})
1410 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${input})
1411 SET(output ${CMAKE_CURRENT_BINARY_DIR}/${output})
1414 COMMAND ${QT_UIC_EXECUTABLE} -o ${output} ${input}
1415 MAIN_DEPENDENCY ${input}
1417 ENDFOREACH(output ${UIC_FILES})
1424 if self.__thedict__.has_key(key):
1426 FOREACH(output ${QRC_FILES})
1427 STRING(REGEX REPLACE "qrc_" "" input ${output})
1428 STRING(REGEX REPLACE ".cxx" ".qrc" input ${input})
1429 STRING(REGEX REPLACE ".qrc" "" name ${input})
1430 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${input})
1431 SET(output ${CMAKE_CURRENT_BINARY_DIR}/${output})
1434 COMMAND ${QT_RCC_EXECUTABLE} ${input} -o ${output} -name ${name}
1435 MAIN_DEPENDENCY ${input}
1437 ENDFOREACH(output ${QRC_FILES})
1444 if self.__thedict__.has_key(key):
1446 FOREACH(input ${SIP_FILES})
1447 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${input})
1449 FOREACH(out ${SIP_SRC})
1450 SET(output ${output} ${CMAKE_CURRENT_BINARY_DIR}/${out})
1451 ENDFOREACH(out ${SIP_SRC})
1454 COMMAND ${SIP_EXECUTABLE} ${PYQT_SIPFLAGS} ${input}
1455 MAIN_DEPENDENCY ${input}
1457 ENDFOREACH(input ${SIP_FILES})
1464 for key in ["TESTS"]:
1465 if self.__thedict__.has_key(key):
1467 SET(UNIT_TEST_PROG ${%s})
1469 self.__thedict__["UNIT_TEST_PROG"] = self.__thedict__[key]
1472 key = "UNIT_TEST_PROG"
1473 if self.__thedict__.has_key(key):
1475 FOREACH(input ${UNIT_TEST_PROG})
1476 GET_FILENAME_COMPONENT(ext ${input} EXT)
1477 IF(ext STREQUAL .py)
1478 SET(test ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/${input})
1479 ELSE(ext STREQUAL .py)
1481 SET(test ${CMAKE_CURRENT_BINARY_DIR}/${input}_exe.exe)
1483 SET(test ${CMAKE_CURRENT_BINARY_DIR}/${input}_exe)
1485 ENDIF(ext STREQUAL .py)
1486 ADD_TEST(${input} ${test})
1487 SET(fail_regex "KO")
1488 SET_PROPERTY(TEST ${input} PROPERTY FAIL_REGULAR_EXPRESSION "${fail_regex}")
1490 # ADD_TEST(${input}_valgrind valgrind ${test})
1491 # SET_PROPERTY(TEST ${input}_valgrind PROPERTY FAIL_REGULAR_EXPRESSION "${fail_regex}")
1492 # SET_PROPERTY(TEST ${input}_valgrind PROPERTY PASS_REGULAR_EXPRESSION "no leaks are possible")
1494 ENDFOREACH(input ${UNIT_TEST_PROG})
1499 # Treat the install targets
1501 resdir = self.module
1502 if resdir == "hxx2salome":
1503 resdir = self.hxxmodule
1506 "salomeadmux_DATA" : "salome_adm/unix",
1507 "dist_salomeadmux_DATA" : "salome_adm/unix",
1508 "dist_salome_cmake_DATA" : "salome_adm/cmake_files",
1509 "dist_salomem4_DATA" : "salome_adm/unix/config_files",
1510 "dist_salome4depr_DATA" : "salome_adm/unix/config_files/DEPRECATED",
1511 "dist_admlocalm4_DATA" : "adm_local/unix/config_files",
1512 "dist_admlocal_cmake_DATA" : "adm_local/cmake_files",
1513 "salomeinclude_DATA" : "include/salome",
1514 "salomeinclude_HEADERS" : "include/salome",
1515 "nodist_salomeinclude_HEADERS" : "include/salome",
1516 "dist_salomeres_DATA" : "share/salome/resources/%s"%(resdir),
1517 "nodist_salomeres_DATA" : "share/salome/resources/%s"%(resdir),
1518 "nodist_salomeres_SCRIPTS" : "share/salome/resources/%s"%(resdir),
1519 "dist_salomescript_SCRIPTS" : "bin/salome",
1520 "dist_salomescript_DATA" : "bin/salome",
1521 "dist_salomescript_PYTHON" : "bin/salome",
1522 "nodist_salomescript_DATA" : "bin/salome",
1523 "salomepython_PYTHON" : "${salomepythondir}",
1524 "nodist_salomepython_PYTHON" : "${salomepythondir}",
1525 "dist_salomepython_DATA" : "${salomepythondir}",
1526 "sharedpkgpython_PYTHON" : "${salomepythondir}/shared_modules",
1527 "salomepypkg_PYTHON" : "${salomepypkgdir}",
1528 "mypkgpython_PYTHON" : "${mypkgpythondir}",
1530 if self.module == "jobmanager":
1531 d["bin_SCRIPTS"] = "bin"
1533 if self.module == "medfile":
1535 "include_HEADERS" : "include",
1536 "nodist_include_HEADERS" : "include",
1537 "bin_SCRIPTS" : "bin",
1538 "doc_DATA" : "${docdir}",
1541 if self.module == "netgen":
1543 "include_HEADERS" : "include",
1544 "noinst_HEADERS" : "share/netgen/include",
1545 "dist_pkgdata_DATA" : "share/netgen",
1546 "dist_doc_DATA" : "share/doc/netgen",
1549 for key, value in d.items():
1550 if self.__thedict__.has_key(key):
1551 self.addInstallTarget(key, value, newlines)
1558 def setLibAdd(self, key, newlines):
1560 newlines.append(r'''
1564 newlines.append(r'''
1567 SET(targets ${targets} MEFISTO2D)
1568 FOREACH(target ${targets})
1569 IF(name STREQUAL ${target})
1570 SET(dir $ENV{F2CHOME})
1571 STRING(REPLACE "\\\\" "/" dir ${dir})
1572 SET(libadd ${libadd} ${dir}/LIBF77.lib)
1573 SET(libadd ${libadd} ${dir}/LIBI77.lib)
1574 ENDIF(name STREQUAL ${target})
1575 ENDFOREACH(target ${targets})
1579 newlines.append(r'''
1580 SET(libs ${PLATFORM_LIBADD} ${PLATFORM_LDFLAGS} ${LDADD} ${${amname}_LIBADD} ${${amname}_LDADD} ${${amname}_LDFLAGS})
1581 FOREACH(lib SALOMEBasics SalomeBatch)
1582 IF(name STREQUAL lib)
1583 SET(libs ${libs} ${PTHREAD_LIBS})
1584 ENDIF(name STREQUAL lib)
1585 ENDFOREACH(lib SALOMEBasics SalomeBatch)
1588 newlines.append(r'''
1589 FOREACH(lib ${libs})
1590 GET_FILENAME_COMPONENT(ext ${lib} EXT)
1591 IF(ext STREQUAL .la)
1592 GET_FILENAME_COMPONENT(lib ${lib} NAME_WE)
1593 STRING(REGEX REPLACE "^lib" "" lib ${lib})
1594 ENDIF(ext STREQUAL .la)
1596 SET(vars ${vars} -no-undefined)
1597 SET(vars ${vars} -lvtkWidgets)
1599 SET(vars ${vars} -module)
1600 SET(vars ${vars} -Wl,-E)
1601 SET(vars ${vars} -Xlinker)
1602 SET(vars ${vars} -export-dynamic)
1603 SET(vars ${vars} -lm)
1604 SET(vars ${vars} -lboost_thread)
1605 SET(vars ${vars} -lboost_signals)
1606 SET(vars ${vars} -pthread -lpthread -ldl)
1611 ENDIF(lib STREQUAL v)
1612 ENDFOREACH(v ${vars})
1615 STRING(REGEX MATCH "^-lQt" test ${lib})
1618 SET(libadd ${libadd} ${lib})
1620 ENDFOREACH(lib ${libs})
1621 TARGET_LINK_LIBRARIES(${name} ${libadd})
1624 newlines.append(r'''
1627 SET(targets ${targets} MEFISTO2D)
1628 FOREACH(target ${targets})
1629 IF(name STREQUAL ${target})
1630 IF(CMAKE_BUILD_TYPE STREQUAL Debug)
1631 SET_TARGET_PROPERTIES(${name} PROPERTIES LINK_FLAGS "/NODEFAULTLIB:MSVCRT")
1632 ENDIF(CMAKE_BUILD_TYPE STREQUAL Debug)
1633 ENDIF(name STREQUAL ${target})
1634 ENDFOREACH(target ${targets})
1640 def setCompilationFlags(self, key, newlines):
1641 newlines.append(r'''
1645 SET(targets ${targets} SalomeIDLKernel)
1646 SET(targets ${targets} SalomeDS)
1647 SET(targets ${targets} SALOMEDSTest)
1648 SET(targets ${targets} SALOMEDS_Client_exe)
1649 SET(targets ${targets} SalomeIDLGEOM)
1650 SET(targets ${targets} GEOMEngine)
1651 SET(targets ${targets} MEDEngine)
1652 SET(targets ${targets} SMESHEngine)
1653 SET(targets ${targets} SMESH)
1654 FOREACH(target ${targets})
1655 IF(name STREQUAL ${target})
1656 SET(var ${var} -DNOGDI)
1657 ENDIF(name STREQUAL ${target})
1658 ENDFOREACH(target ${targets})
1662 if self.module in ["medfile", "yacs"]:
1663 newlines.append(r'''
1665 SET(var ${var} -DNOGDI)
1670 newlines.append(r'''
1673 SET(targets ${targets} MEFISTO2D)
1674 FOREACH(target ${targets})
1675 IF(name STREQUAL ${target})
1676 SET(dir $ENV{F2CHOME})
1677 STRING(REPLACE "\\\\" "/" dir ${dir})
1678 SET(var ${var} -I${dir})
1679 SET(var ${var} -DF2C_BUILD)
1680 ENDIF(name STREQUAL ${target})
1681 ENDFOREACH(target ${targets})
1685 if self.module in ["geom", "med"]:
1686 newlines.append(r'''
1687 SET(var ${var} -I${CMAKE_CURRENT_SOURCE_DIR})
1688 SET(var ${var} -I${CMAKE_CURRENT_BINARY_DIR})
1691 newlines.append(r'''
1692 SET(var ${var} ${AM_CPPFLAGS})
1693 SET(var ${var} ${AM_CXXFLAGS})
1696 newlines.append(r'''
1697 IF(type STREQUAL STATIC)
1698 SET(var ${var} -fPIC)
1699 ENDIF(type STREQUAL STATIC)
1702 if self.module == "yacs":
1703 newlines.append(r'''
1704 SET(var ${var} -DYACS_PTHREAD)
1705 SET(var ${var} -DCMAKE_BUILD)
1706 SET(var ${var} -DSALOME_KERNEL)
1707 SET(var ${var} -DDSC_PORTS)
1708 SET(var ${var} -DOMNIORB)
1711 newlines.append(r'''
1712 SET(var ${var} ${PLATFORM_CPPFLAGS})
1713 SET(var ${var} ${PTHREAD_CFLAGS})
1714 SET(var ${var} ${${amname}_CPPFLAGS})
1715 SET(var ${var} ${${amname}_CXXFLAGS})
1716 SET(var ${var} ${${amname}_CFLAGS})
1719 SET(vars ${vars} -include SALOMEconfig.h)
1720 SET(vars ${vars} -ftemplate-depth-32)
1721 SET(vars ${vars} -fPIC)
1722 SET(vars ${vars} -g)
1730 ENDFOREACH(v ${vars})
1732 string(REGEX MATCH "^-I" test_include ${f})
1734 string(REGEX REPLACE "^-I" "" include_dir ${f})
1736 if(include_dir STREQUAL /usr/include)
1737 else(include_dir STREQUAL /usr/include)
1738 string(REGEX MATCH "^\\." test_dot ${include_dir})
1740 set(include_dir ${CMAKE_CURRENT_BINARY_DIR}/${include_dir})
1742 include_directories(${include_dir})
1743 endif(include_dir STREQUAL /usr/include)
1746 SET(flags "${flags} ${f}")
1749 ENDFOREACH(f ${var})
1750 SET_TARGET_PROPERTIES(${name} PROPERTIES COMPILE_FLAGS "${flags}")
1754 def addLibTarget(self, key, newlines):
1755 newlines.append(r'''
1756 FOREACH(amname ${%s})
1759 # Replace .la by _la ...
1761 newlines.append(r'''
1762 STRING(REPLACE .la _la amname ${amname})
1765 # Remove the _la for the cmake name
1767 newlines.append(r'''
1768 STRING(LENGTH ${amname} len)
1769 MATH(EXPR newlen "${len}-3")
1770 STRING(SUBSTRING ${amname} 0 ${newlen} name)
1773 # Does the target begins with lib ??
1774 # If yes, remove lib at beginning for cmake name
1776 newlines.append(r'''
1777 STRING(REGEX MATCH "^lib" BEGIN_WITH_lib ${name})
1779 STRING(LENGTH ${name} len)
1780 MATH(EXPR newlen "${len}-3")
1781 STRING(SUBSTRING ${name} 3 ${newlen} name)
1782 ENDIF(BEGIN_WITH_lib)
1785 # Does the target is an idl library
1787 newlines.append(r'''
1788 STRING(REGEX MATCH "IDL" ISIDL ${name})
1791 # Set the type of the library
1793 newlines.append(r'''
1804 if key == "noinst_LTLIBRARIES":
1805 newlines.append(r'''
1814 # Set sources for the library
1816 newlines.append(r'''
1818 FOREACH(src ${${amname}_SOURCES} ${dist_${amname}_SOURCES})
1819 GET_FILENAME_COMPONENT(ext ${src} EXT)
1821 IF(src STREQUAL trte.f)
1822 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${src})
1823 STRING(REPLACE ".f" ".c" src ${src})
1824 SET(src ${CMAKE_CURRENT_BINARY_DIR}/${src})
1828 IF(CMAKE_SIZEOF_VOID_P STREQUAL 8)
1829 SET(cmd valgrind f2c) # f2c seems to be buggy on 64 bits ... but with valgrind, it works :)
1834 COMMAND ${cmd} ${input}
1835 MAIN_DEPENDENCY ${input}
1837 ELSE(src STREQUAL trte.f)
1838 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${src})
1839 STRING(REPLACE ".f" ".o" src ${src})
1840 SET(src ${CMAKE_CURRENT_BINARY_DIR}/${src})
1849 COMMAND ${F77} -c -o ${output} ${input}
1850 MAIN_DEPENDENCY ${input}
1852 ENDIF(src STREQUAL trte.f)
1853 ENDIF(ext STREQUAL .f)
1854 SET(srcs ${srcs} ${src})
1855 ENDFOREACH(src ${${amname}_SOURCES} ${dist_${amname}_SOURCES})
1857 newlines.append(r'''
1858 SET(l ${nodist_${amname}_SOURCES} ${UIC_FILES})
1860 SET(src ${CMAKE_CURRENT_BINARY_DIR}/${f})
1861 SET(srcs ${srcs} ${src})
1864 newlines.append(r'''
1866 SET(l ${nodist_${amname}_SOURCES} ${BUILT_SOURCES})
1868 GET_FILENAME_COMPONENT(ext ${f} EXT)
1869 IF(ext STREQUAL .py)
1871 ELSE(ext STREQUAL .py)
1872 SET(fff ${CMAKE_CURRENT_BINARY_DIR}/${f})
1873 ENDIF(ext STREQUAL .py)
1876 LIST(FIND build_srcs ${fff} index)
1877 IF(NOT index EQUAL -1)
1879 ENDIF(NOT index EQUAL -1)
1883 SET(build_srcs ${build_srcs} ${fff})
1888 # Add the library to cmake
1890 newlines.append(r'''
1891 ADD_LIBRARY(${name} ${type} ${srcs})
1894 # The compilation flags
1896 self.setCompilationFlags(key, newlines)
1898 newlines.append(r'''
1899 SET_TARGET_PROPERTIES(${name} PROPERTIES VERSION ${VERSION_INFO} SOVERSION ${SOVERSION_INFO})
1902 self.setLibAdd(key, newlines)
1904 if 1: # key != "noinst_LTLIBRARIES":
1905 newlines.append(r'''
1908 newlines.append(r'''
1910 IF(${key} STREQUAL noinst_LTLIBRARIES)
1912 ENDIF(${key} STREQUAL noinst_LTLIBRARIES)
1914 if self.module == "netgen" :
1915 newlines.append(r'''
1916 IF(${key} STREQUAL noinst_LTLIBRARIES)
1920 ENDIF(${key} STREQUAL noinst_LTLIBRARIES)
1923 newlines.append(r'''
1926 if self.module in ["medfile", "netgen"]:
1927 newlines.append(r'''
1931 newlines.append(r'''
1932 SET(DEST lib/salome)
1935 newlines.append(r'''
1937 INSTALL(TARGETS ${name} DESTINATION ${DEST})
1939 if self.module == "gui":
1940 newlines.append(r'''
1941 FOREACH(lib SalomePyQt)
1942 IF(name STREQUAL lib)
1944 IF(CMAKE_BUILD_TYPE STREQUAL Release)
1945 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.dll DESTINATION ${DEST} RENAME ${name}.pyd)
1946 ELSE(CMAKE_BUILD_TYPE STREQUAL Release)
1947 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.dll DESTINATION ${DEST} RENAME ${name}_d.pyd)
1948 ENDIF(CMAKE_BUILD_TYPE STREQUAL Release)
1950 INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/lib${name}.so DESTINATION ${DEST} RENAME ${name}.so)
1952 ENDIF(name STREQUAL lib)
1953 ENDFOREACH(lib SalomePyQt)
1954 FOREACH(lib SalomePy)
1955 IF(name STREQUAL lib)
1957 IF(CMAKE_BUILD_TYPE STREQUAL Release)
1958 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.dll DESTINATION ${DEST} RENAME lib${name}.pyd)
1959 ELSE(CMAKE_BUILD_TYPE STREQUAL Release)
1960 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.dll DESTINATION ${DEST} RENAME lib${name}_d.pyd)
1961 ENDIF(CMAKE_BUILD_TYPE STREQUAL Release)
1963 ENDIF(name STREQUAL lib)
1964 ENDFOREACH(lib SalomePy)
1967 if self.module == "geom":
1968 newlines.append(r'''
1970 STRING(REGEX MATCH "Export" ISExport ${name})
1972 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.dll DESTINATION ${DEST} RENAME lib${name}.dll)
1974 STRING(REGEX MATCH "Import" ISImport ${name})
1976 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.dll DESTINATION ${DEST} RENAME lib${name}.dll)
1981 newlines.append(r'''
1982 ELSE(BEGIN_WITH_lib)
1984 newlines.append(r'''
1986 INSTALL(TARGETS ${name} DESTINATION ${salomepythondir})
1987 IF(CMAKE_BUILD_TYPE STREQUAL Release)
1988 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${salomepythondir}/${name}.dll DESTINATION ${salomepythondir} RENAME ${name}.pyd)
1989 ELSE(CMAKE_BUILD_TYPE STREQUAL Release)
1990 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${salomepythondir}/${name}.dll DESTINATION ${salomepythondir} RENAME ${name}_d.pyd)
1991 ENDIF(CMAKE_BUILD_TYPE STREQUAL Release)
1993 GET_TARGET_PROPERTY(version ${name} VERSION)
1994 GET_TARGET_PROPERTY(soversion ${name} SOVERSION)
1995 INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/lib${name}.so.${version} DESTINATION ${salomepythondir} RENAME ${name}.so.${version})
1996 INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/lib${name}.so.${version} DESTINATION ${salomepythondir} RENAME ${name}.so.${soversion})
1997 INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/lib${name}.so.${version} DESTINATION ${salomepythondir} RENAME ${name}.so)
2000 newlines.append(r'''
2001 ENDIF(BEGIN_WITH_lib)
2003 newlines.append(r'''
2008 newlines.append(r'''
2009 ENDFOREACH(amname ${%s})
2014 def addBinTarget(self, key, newlines):
2016 newlines.append(r'''
2017 FOREACH(amname ${%s})
2020 newlines.append(r'''
2023 if key == "check_PROGRAMS":
2024 newlines.append(r'''
2026 STRING(REGEX MATCH ${amname} is_present ${bin_PROGRAMS})
2033 newlines.append(r'''
2037 newlines.append(r'''
2038 SET(name "${amname}_exe")
2039 SET(srcs ${${amname}_SOURCES} ${dist_${amname}_SOURCES})
2040 SET(l ${nodist_${amname}_SOURCES})
2042 SET(src ${CMAKE_CURRENT_BINARY_DIR}/${f})
2043 SET(srcs ${srcs} ${src})
2045 LIST(LENGTH srcs nb)
2047 ADD_EXECUTABLE(${name} ${srcs})
2050 self.setCompilationFlags(key, newlines)
2052 self.setLibAdd(key, newlines)
2054 if self.module in ["jobmanager", "medfile", "netgen"]:
2055 newlines.append(r'''
2059 newlines.append(r'''
2060 SET(DEST bin/salome)
2064 if key == "bin_PROGRAMS":
2065 newlines.append(r'''
2067 INSTALL(TARGETS ${name} DESTINATION ${DEST})
2068 INSTALL(FILES ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.exe DESTINATION ${DEST} RENAME ${amname}.exe)
2069 INSTALL(CODE "FILE(REMOVE ${CMAKE_INSTALL_PREFIX}/${DEST}/${name}.exe)")
2072 SET(PERMS ${PERMS} OWNER_READ OWNER_WRITE OWNER_EXECUTE)
2073 SET(PERMS ${PERMS} GROUP_READ GROUP_EXECUTE)
2074 SET(PERMS ${PERMS} WORLD_READ WORLD_EXECUTE)
2075 INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/${name} DESTINATION ${DEST} PERMISSIONS ${PERMS} RENAME ${amname})
2080 newlines.append(r'''
2084 newlines.append(r'''
2087 newlines.append(r'''
2088 ENDFOREACH(amname ${%s})
2093 def addInstallTarget(self, key, destination, newlines):
2094 newlines.append(r"FOREACH(f ${%s})"%(key))
2095 newlines.append(r'''
2098 newlines.append(r'''
2099 STRING(COMPARE EQUAL ${f} SALOMEconfig.h.in test_SALOMEconfig.h.in)
2100 IF(test_SALOMEconfig.h.in)
2101 INSTALL(FILES SALOMEconfig.ref.in DESTINATION ${DEST} RENAME SALOMEconfig.h.in)
2102 ELSE(test_SALOMEconfig.h.in)
2103 SET(dummy dummy-NOTFOUND)
2104 MARK_AS_ADVANCED(dummy)
2105 # FILE(REMOVE ${CMAKE_INSTALL_PREFIX}/${DEST}/${f})
2106 FIND_FILE(dummy ${f} PATHS ${CMAKE_CURRENT_SOURCE_DIR} NO_DEFAULT_PATH)
2109 if key in ['dist_salomescript_SCRIPTS']:
2110 newlines.append(r'''
2112 SET(PERMS ${PERMS} OWNER_READ OWNER_WRITE OWNER_EXECUTE)
2113 SET(PERMS ${PERMS} GROUP_READ GROUP_EXECUTE)
2114 SET(PERMS ${PERMS} WORLD_READ WORLD_EXECUTE)
2115 INSTALL(FILES ${f} DESTINATION ${DEST} PERMISSIONS ${PERMS})
2118 newlines.append(r'''
2119 GET_FILENAME_COMPONENT(ext ${f} EXT)
2120 IF(ext STREQUAL .py)
2121 IF(DEST STREQUAL bin/salome)
2123 SET(PERMS ${PERMS} OWNER_READ OWNER_WRITE OWNER_EXECUTE)
2124 SET(PERMS ${PERMS} GROUP_READ GROUP_EXECUTE)
2125 SET(PERMS ${PERMS} WORLD_READ WORLD_EXECUTE)
2126 INSTALL(FILES ${f} DESTINATION ${DEST} PERMISSIONS ${PERMS})
2127 ELSE(DEST STREQUAL bin/salome)
2128 INSTALL(FILES ${f} DESTINATION ${DEST})
2129 ENDIF(DEST STREQUAL bin/salome)
2130 ELSE(ext STREQUAL .py)
2131 INSTALL(FILES ${f} DESTINATION ${DEST})
2132 ENDIF(ext STREQUAL .py)
2135 newlines.append(r'''
2137 GET_FILENAME_COMPONENT(ext ${f} EXT)
2138 IF(ext STREQUAL .qm)
2139 STRING(REGEX REPLACE .qm .ts input ${f})
2141 if self.module in ["kernel", "gui", "yacs"]:
2142 newlines.append(r'''
2143 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/resources/${input})
2146 newlines.append(r'''
2147 SET(input ${CMAKE_CURRENT_SOURCE_DIR}/${input})
2150 newlines.append(r'''
2151 SET(output ${CMAKE_CURRENT_BINARY_DIR}/${f})
2152 # ADD_CUSTOM_COMMAND(
2154 # COMMAND ${QT_LRELEASE_EXECUTABLE} ${input} -qm ${output}
2155 # MAIN_DEPENDENCY ${input}
2157 EXECUTE_PROCESS(COMMAND ${QT_LRELEASE_EXECUTABLE} ${input} -qm ${output})
2158 ENDIF(ext STREQUAL .qm)
2159 INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/${f} DESTINATION ${DEST})
2161 ENDIF(test_SALOMEconfig.h.in)
2163 newlines.append(r'''
2164 GET_FILENAME_COMPONENT(ext ${f} EXT)
2165 IF(ext STREQUAL .py)
2166 INSTALL(CODE "SET(PYTHON_FILE ${f})")
2167 INSTALL(CODE "SET(CMAKE_INSTALL_PREFIX ${CMAKE_INSTALL_PREFIX})")
2168 INSTALL(CODE "SET(DEST ${DEST})")
2169 INSTALL(CODE "SET(PYTHON_EXECUTABLE ${PYTHON_EXECUTABLE})")
2171 if self.module == "kernel":
2173 IF(f STREQUAL SALOME_ContainerPy.py)
2174 ELSE(f STREQUAL SALOME_ContainerPy.py)
2175 IF(f STREQUAL am2cmake.py)
2176 ELSE(f STREQUAL am2cmake.py)
2177 IF(f STREQUAL copytree1.py)
2178 ELSE(f STREQUAL copytree1.py)
2179 INSTALL(SCRIPT ${CMAKE_SOURCE_DIR}/salome_adm/cmake_files/install_and_compile_python_file.cmake)
2180 ENDIF(f STREQUAL copytree1.py)
2181 ENDIF(f STREQUAL am2cmake.py)
2182 ENDIF(f STREQUAL SALOME_ContainerPy.py)
2186 STRING(REPLACE "\\\\" "/" KERNEL_ROOT_DIR ${KERNEL_ROOT_DIR})
2187 INSTALL(SCRIPT ${KERNEL_ROOT_DIR}/salome_adm/cmake_files/install_and_compile_python_file.cmake)
2190 newlines.append(r'''
2191 ENDIF(ext STREQUAL .py)
2193 newlines.append(r"ENDFOREACH(f ${%s})"%(key))
2196 def writeListsFile(self):
2197 f = open(self.listsFile, "w")
2198 f.write(self.content)
2204 def convertAmFile(the_root, root, dirs, files, f, module):
2205 cmake = CMakeFile(the_root, root, dirs, files, f, module)
2206 cmake.writeListsFile()
2209 def usage(exit_status):
2210 from sys import exit
2211 from sys import argv
2212 print "Usage: %s --module"%(argv[0])
2216 if __name__ == "__main__":
2218 from sys import argv
2224 if module.find('--') != 0:
2228 if len(module) == 0:
2232 from os import getcwd
2238 for root, dirs, files in walk(the_root):
2240 # E.A. : Remove 'CVS' in dirs
2241 # E.A. : It allows to not recurse in CVS dirs
2242 # E.A. : See os module python documentation
2249 if "Makefile.am.cmake" in files:
2250 if "Makefile.am" in files:
2251 files.remove("Makefile.am")
2255 from sys import stdout
2257 if f in ["Makefile.am", "Makefile.am.cmake"]:
2258 convertAmFile(the_root, root, dirs, files, f, module)
2266 msg = "%s file has been converted to cmake"%(nok)
2268 msg = "%s files have been converted to cmake"%(nok)