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.
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.
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.
20 # ======================================================================
22 Ce module contient le plugin generateur de fichier au format
27 import types,string,re,os
29 from datetime import date
31 from generator_python import PythonGenerator
33 sys.path.append(os.path.join(os.getenv('MAP_DIRECTORY'),'classes/python/'))
34 from class_MAP_parameters import *
42 Retourne les informations necessaires pour le chargeur de plugins
43 Ces informations sont retournees dans un dictionnaire
48 # La factory pour creer une instance du plugin
49 'factory' : MapGenerator,
53 class MapGenerator(PythonGenerator):
55 Ce generateur parcourt un objet de type JDC et produit
56 un texte au format eficas et
60 # Les extensions de fichier permis?
64 def initialise(self,config):
66 self.nom_racine=self.config.PATH_STUDY+"/"+self.config.NAME_SCHEME+"/"
67 if not( os.path.exists(self.nom_racine)):
68 os.makedirs(self.nom_racine)
72 self.ssCode=self.config.appli.ssCode
73 self.INSTALLDIR=self.config.appli.INSTALLDIR
74 self.ssCodeDir=os.path.join(self.INSTALLDIR,'MAP/Templates',self.ssCode)
75 self.fichierYacs=self.ssCode+"_YACS_nodes"
76 self.texteExecution="import os,sys\n"
77 self.texteExecution+="sys.path.append('"+self.ssCodeDir+"')\n"
78 self.texteExecution+="from " + self.fichierYacs +" import *\n"
80 def gener(self,obj,format='brut',config=None):
81 self.initialise(config)
82 text=PythonGenerator.gener(self,obj,format)
85 def generRUN(self,obj,format='brut',config=None,):
86 self.initialise(config)
87 text=PythonGenerator.gener(self,obj,format)
88 for elt in self.listeCODE:
91 if code in self.__class__.__dict__.keys():
92 texteCode=apply(self.__class__.__dict__[code],(self,))
93 self.texteExecution += texteCode
94 return self.texteExecution
97 def generRUNYACS(self,obj,format='brut',config=None,nomFichier=None):
98 self.initialise(config)
99 text=PythonGenerator.gener(self,obj,format)
100 #self.generePythonMap("non")
103 sys.path.append(os.path.join(os.getenv("YACS_ROOT_DIR"),"lib/python2.4/site-packages/salome/"))
105 self.monSchema=monCreateYacs.getSchema(config)
106 self.proc=self.monSchema.createProc(self)
107 for elt in self.listeCODE:
110 if code in self.__class__.__dict__.keys():
111 codeYACS=str(code)+"YACS"
112 if hasattr(self.monSchema, codeYACS):
113 fct=getattr(self.monSchema, codeYACS)
116 print str(nomFichier)
117 self.monSchema.write_yacs_proc(self.proc,str(nomFichier))
119 def generePythonMap(self,execution) :
121 self.dictMCVal est un dictionnaire qui est indexe par le nom du code (exple PYGMEE)
122 la valeur associee a la clef est egalement un dictionnaire
123 ce dictionnaire a pour clef la genealogie du MCSimp suivi de sa valeur
126 for elt in self.listeCODE:
130 self.dictMCVal[code]=dico
131 if code in self.__class__.__dict__.keys():
132 texteCode=apply(self.__class__.__dict__[code],(self,execution))
133 self.texteExecution=self.texteExecution+texteCode
135 def generPROC_ETAPE(self,obj):
137 s=PythonGenerator.generPROC_ETAPE(self,obj)
139 dico[obj.nom]=self.DictTemp
140 self.listeCODE.append(dico)
141 if hasattr(obj.definition,"mcOblig") :
142 for clef in obj.definition.mcOblig.keys():
143 setattr(self,clef,obj.definition.mcOblig[clef])
147 def generMCSIMP(self,obj) :
149 Convertit un objet MCSIMP en texte python
151 s=PythonGenerator.generMCSIMP(self,obj)
153 #for i in obj.get_genealogie() :
155 self.DictTemp[obj.nom]=obj.valeur
156 if hasattr(obj.definition,'equiv') and obj.definition.equiv!= None:
157 setattr(self,obj.definition.equiv,obj.valeur)
159 setattr(self,obj.nom,obj.valeur)
163 def remplaceCONFIG(self,chaine,liste) :
166 result=chaine.replace(rplact,self.config.__dict__[mot])
171 def remplaceDICO(self,chaine,dico) :
172 for mot in dico.keys() :
174 result=chaine.replace(rplact,str(dico[mot]))