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
23 openturns pour EFICAS.
27 import types,string,re
29 from generator_python import PythonGenerator
30 from OpenturnsBase import Generateur
31 #from OpenturnsXML import XMLGenerateur
32 #from OpenturnsSTD import STDGenerateur
36 Retourne les informations necessaires pour le chargeur de plugins
38 Ces informations sont retournees dans un dictionnaire
42 'name' : 'openturns_study',
43 # La factory pour creer une instance du plugin
44 'factory' : OpenturnsGenerator,
48 class OpenturnsGenerator(PythonGenerator):
50 Ce generateur parcourt un objet de type JDC et produit
51 un texte au format eficas et
52 un texte au format xml
55 # Les extensions de fichier permis?
60 self.listeVariables=[]
65 self.texteSTD="""#!/usr/bin/env python
67 print "Invalid file. Check build process."
71 def gener(self,obj,format='brut'):
72 print "IDM: gener dans generator_openturns_study.py"
74 self.text=PythonGenerator.gener(self,obj,format)
78 def generMCSIMP(self,obj) :
80 Convertit un objet MCSIMP en texte python
81 Remplit le dictionnaire des MCSIMP si nous ne sommes ni dans une loi, ni dans une variable
83 s=PythonGenerator.generMCSIMP(self,obj)
84 if self.TraiteMCSIMP == 1 :
85 self.dictMCVal[obj.nom]=obj.val
87 self.dictTempo[obj.nom]=obj.valeur
90 # def generMCFACT(self,obj):
91 # # Il n est pas possible d utiliser obj.valeur qui n est pas
92 # # a jour pour les nouvelles variables ou les modifications
93 # if obj.nom in ( "Variables", "Files", ) :
96 # s=PythonGenerator.generMCFACT(self,obj)
97 # if obj.nom in ( "Variables", ) :
98 # self.listeVariables.append(self.dictTempo)
101 # self.listeFichiers.append(self.dictTempo)
102 # self.TraiteMCSIMP=1
105 def generETAPE(self,obj):
106 print "IDM: generETAPE dans generator_openturns_study.py"
107 print "IDM: obj.nom=", obj.nom
108 if obj.nom in ( "DISTRIBUTION", ) :
111 s=PythonGenerator.generETAPE(self,obj)
112 if obj.nom in ( "DISTRIBUTION", ) :
113 self.dictMCLois[obj.sd]=self.dictTempo
118 def generPROC_ETAPE(self,obj):
119 print "IDM: generPROC_ETAPE dans generator_openturns_study.py"
120 print "IDM: obj.nom=", obj.nom
121 if obj.nom in ( "VARIABLE", ) :
124 s=PythonGenerator.generPROC_ETAPE(self,obj)
125 if obj.nom in ( "VARIABLE", ) :
126 self.listeVariables.append(self.dictTempo)
132 print "IDM: genereSTD dans generator_openturns_study.py"
133 print "IDM: self.listeVariables=", self.listeVariables
134 MonBaseGenerateur=Generateur(self.appli,self.dictMCVal, self.listeVariables, self.dictMCLois)
135 MonGenerateur=MonBaseGenerateur.getSTDGenerateur()
138 self.texteSTD=MonGenerateur.CreeSTD()
141 self.texteSTD="Il y a un pb a la Creation du STD"
143 def writeOpenturnsSTD(self, filename):
144 f = open( str(filename), 'wb')
145 f.write( self.texteSTD )