Salome HOME
*** empty log message ***
[tools/eficas.git] / generator / generator_SEP.py
1 # -*- coding: utf-8 -*-
2 #            CONFIGURATION MANAGEMENT OF EDF VERSION
3 # ======================================================================
4 # COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
5 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
6 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
7 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
8 # (AT YOUR OPTION) ANY LATER VERSION.
9 #
10 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
11 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
12 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
13 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
14 #
15 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
16 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
17 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
18 #
19 #
20 # ======================================================================
21 """
22    Ce module contient le plugin generateur de fichier au format 
23    SEP pour EFICAS.
24
25 """
26 import traceback
27 import types,string,re,os
28
29 from generator_python import PythonGenerator
30
31 def entryPoint():
32    """
33       Retourne les informations necessaires pour le chargeur de plugins
34
35       Ces informations sont retournees dans un dictionnaire
36    """
37    return {
38         # Le nom du plugin
39           'name' : 'SEP',
40         # La factory pour creer une instance du plugin
41           'factory' : SEPGenerator,
42           }
43
44
45 class SEPGenerator(PythonGenerator):
46    """
47       Ce generateur parcourt un objet de type JDC et produit
48       un texte au format eficas et 
49       un texte au format py 
50
51    """
52    # Les extensions de fichier permis?
53    extensions=('.comm',)
54
55    def gener(self,obj,format='brut'):
56       self.initDico()
57       self.text=PythonGenerator.gener(self,obj,format)
58       self.genereSEP()
59       return self.text
60
61    def getTubePy(self) :
62       return self.texteTubePy
63
64    def genereSEP(self) :
65       self.texteTubePy="# Parametres generes par Eficas \n"
66       for MC in self.dictMCVal.keys():
67          ligne = MC +"="+ repr(self.dictMCVal[MC])+'\n'
68          self.texteTubePy=self.texteTubePy+ligne
69       print self.texteTubePy
70
71       fichier=os.path.join(os.path.dirname(__file__),"tube.py")
72       f=open(fichier,'r')
73       for ligne in f.readlines():
74          self.texteTubePy=self.texteTubePy+ligne
75       f.close
76
77    def initDico(self) :
78       self.tube=0
79       self.coude=0
80       self.dictMCVal={}
81       self.texteTubePy=""
82
83    def generMCSIMP(self,obj) :
84       """
85       Convertit un objet MCSIMP en texte python
86       Remplit le dictionnaire des MCSIMP si nous ne sommes ni dans une loi, ni dans une variable
87       """
88       s=PythonGenerator.generMCSIMP(self,obj)
89       self.dictMCVal[obj.nom]=obj.valeur
90       return s
91   
92    def generMACRO_ETAPE(self,obj):
93       print obj.nom
94       if obj.nom == "M_TUBE" :
95          self.tube=1
96       if obj.nom == "M_COUDE" :
97          self.coude=1
98       s=PythonGenerator.generMACRO_ETAPE(self,obj)
99       return s
100