]> SALOME platform Git repositories - tools/eficas.git/blob - generator/generator_PSEN.py
Salome HOME
report modif variees + patch CEA
[tools/eficas.git] / generator / generator_PSEN.py
1 # -*- coding: utf-8 -*-
2 # Copyright (C) 2007-2017   EDF R&D
3 #
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.
8 #
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.
13 #
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
17 #
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
19 #
20 """Ce module contient le plugin generateur de fichier au format  Code_Carmel3D pour EFICAS.
21 """
22
23 from __future__ import absolute_import
24 try :
25    from builtins import str
26 except : pass
27
28 texte_debut="int main() \n{ \n   init_var();\n"
29 texte_debut+='   format="med";\n'
30 import traceback
31 import types,re,os
32 from Extensions.i18n import tr
33 from .generator_dicoImbrique import DicoImbriqueGenerator
34
35 def entryPoint():
36    """
37       Retourne les informations necessaires pour le chargeur de plugins
38       Ces informations sont retournees dans un dictionnaire
39    """
40    return {
41         # Le nom du plugin
42           'name' : 'PSEN',
43         # La factory pour creer une instance du plugin
44           'factory' : PSENGenerator,
45           }
46
47
48 class PSENGenerator(DicoImbriqueGenerator):
49    """
50       Ce generateur parcourt un objet de type JDC et produit
51       un texte au format eficas et 
52       un texte au format dictionnaire
53
54    """
55    # Les extensions de fichier permis?
56    extensions=('.comm',)
57
58 #----------------------------------------------------------------------------------------
59    def gener(self,obj,format='brut',config=None, appliEficas=None):
60
61       try :
62          self.MachineDico = obj.MachineDico
63          self.LoadDico = obj.LoadDico
64          self.LineDico = obj.LineDico
65          self.TransfoDico = obj.TransfoDico
66          self.MotorDico = obj.MotorDico
67       except :
68          self.MachineDico = None
69          self.LoadDico = None
70          self.LineDico = None
71          self.TransfoDico = None
72          self.MotorDico = None
73       
74       self.initDico()
75       # Cette instruction genere le contenu du fichier de commandes (persistance)
76       self.text=DicoImbriqueGenerator.gener(self,obj,format)
77       return self.text
78
79
80 #----------------------------------------------------------------------------------------
81 # initialisations
82 #----------------------------------------------------------------------------------------
83    
84    def initDico(self) :
85       DicoImbriqueGenerator.initDico(self)
86       self.Entete = 'MachineDico = ' + str(self.MachineDico) +'\n'
87       self.Entete += 'LoadDico = ' + str(self.LoadDico) +'\n'
88       self.Entete += 'LineDico = ' + str(self.LineDico) +'\n'
89       self.Entete += 'TransfoDico = ' + str(self.TransfoDico) +'\n'
90       self.Entete += 'MotorDico = ' + str(self.MotorDico) + '\n'
91       self.Entete +='\n'
92
93
94 #----------------------------------------------------------------------------------------
95 # ecriture
96 #----------------------------------------------------------------------------------------
97
98    def writeDefault(self,fn) :
99        fileDico=os.path.abspath(os.path.join(os.path.dirname(os.path.abspath(__file__)),'..','PSEN_Eficas','PSEN','PSENconfig.py'))
100        f = open( str(fileDico), 'wb')
101        f.write( self.Entete + "Dico =" + str(self.Dico) )
102        f.close()
103
104    
105
106 #----------------------------------------------------------------------------------------
107 #  analyse de chaque noeud de l'arbre 
108 #----------------------------------------------------------------------------------------
109
110 ##   def generMCSIMP(self,obj) :
111 ##        """recuperation de l objet MCSIMP"""
112 ##        #print dir(obj)
113 ##        self.dicoMCSIMP[obj.nom]=obj.val
114 ##        self.dicoTemp[obj.nom]=obj.val
115 ##        s=DicoImbriqueGenerator.generMCSIMP(self,obj)
116 ##        return s
117 ##
118 ##   def generETAPE(self,obj):
119 ##        self.dicoTemp={}
120 ##        s=DicoImbriqueGenerator.generETAPE(self,obj)
121 ##        if obj.nom=="DISTRIBUTION" : self.dicoLois[obj.sd.nom]=self.dicoTemp
122 ##        self.dicoTemp={}
123 ##        return s
124
125   
126 # si repertoire on change tous les noms de fichier