1 # -*- coding: utf-8 -*-
2 # Copyright (C) 2007-2013 EDF R&D
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
20 """Ce module contient le plugin generateur de fichier au format Code_Carmel3D pour EFICAS.
23 texte_debut="int main() \n{ \n init_var();\n"
24 texte_debut+=' format="med";\n'
26 import types,string,re,os
27 from Extensions.i18n import tr
28 from generator_dicoImbrique import DicoImbriqueGenerator
30 from numpy import zeros
34 Retourne les informations necessaires pour le chargeur de plugins
35 Ces informations sont retournees dans un dictionnaire
40 # La factory pour creer une instance du plugin
41 'factory' : PSENGenerator,
45 class PSENGenerator(DicoImbriqueGenerator):
47 Ce generateur parcourt un objet de type JDC et produit
48 un texte au format eficas et
49 un texte au format dictionnaire
52 # Les extensions de fichier permis?
55 #----------------------------------------------------------------------------------------
56 def gener(self,obj,format='brut',config=None, appli=None):
59 self.MachineDico = obj.MachineDico
60 self.LoadDico = obj.LoadDico
61 self.LineDico = obj.LineDico
62 self.TransfoDico = obj.TransfoDico
63 self.MotorDico = obj.MotorDico
65 self.MachineDico = None
68 self.TransfoDico = None
72 # Cette instruction genere le contenu du fichier de commandes (persistance)
73 self.text=DicoImbriqueGenerator.gener(self,obj,format)
77 #----------------------------------------------------------------------------------------
79 #----------------------------------------------------------------------------------------
82 DicoImbriqueGenerator.initDico(self)
83 self.Entete = 'MachineDico = ' + str(self.MachineDico) +'\n'
84 self.Entete += 'LoadDico = ' + str(self.LoadDico) +'\n'
85 self.Entete += 'LineDico = ' + str(self.LineDico) +'\n'
86 self.Entete += 'TransfoDico = ' + str(self.TransfoDico) +'\n'
87 self.Entete += 'MotorDico = ' + str(self.MotorDico) + '\n'
91 #----------------------------------------------------------------------------------------
93 #----------------------------------------------------------------------------------------
95 def writeDefault(self,fn) :
96 fileDico=os.path.abspath(os.path.join(os.path.dirname(os.path.abspath(__file__)),'..','PSEN_Eficas','PSEN','PSENconfig.py'))
97 f = open( str(fileDico), 'wb')
98 f.write( self.Entete + "Dico =" + str(self.Dico) )
103 #----------------------------------------------------------------------------------------
104 # analyse de chaque noeud de l'arbre
105 #----------------------------------------------------------------------------------------
107 ## def generMCSIMP(self,obj) :
108 ## """recuperation de l objet MCSIMP"""
110 ## self.dicoMCSIMP[obj.nom]=obj.val
111 ## self.dicoTemp[obj.nom]=obj.val
112 ## s=DicoImbriqueGenerator.generMCSIMP(self,obj)
115 ## def generETAPE(self,obj):
117 ## s=DicoImbriqueGenerator.generETAPE(self,obj)
118 ## if obj.nom=="DISTRIBUTION" : self.dicoLois[obj.sd.nom]=self.dicoTemp
123 # si repertoire on change tous les noms de fichier