Salome HOME
CCAR: ajout du repertoire Doc qui contient un Makefile pour générer une doc
[tools/eficas.git] / generator / generator_pyth.py
1 #            CONFIGURATION MANAGEMENT OF EDF VERSION
2 # ======================================================================
3 # COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
4 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
5 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
6 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
7 # (AT YOUR OPTION) ANY LATER VERSION.
8 #
9 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
10 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
11 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
12 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
13 #
14 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
15 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
16 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
17 #
18 #
19 # ======================================================================
20 """
21     Ce module contient le plugin generateur de fichier au format pyth pour EFICAS.
22
23
24 """
25 import traceback
26 import types,string
27
28 from Noyau import N_CR
29 from Accas import MCSIMP,MCFACT
30
31 def entryPoint():
32    """
33        Retourne les informations nécessaires pour le chargeur de plugins
34
35        Ces informations sont retournées dans un dictionnaire
36    """
37    return {
38         # Le nom du plugin
39           'name' : 'pyth',
40         # La factory pour créer une instance du plugin
41           'factory' : PythGenerator,
42           }
43
44
45 class PythGenerator:
46    """
47        Ce generateur parcourt un objet de type MCFACT et produit
48        un fichier au format pyth
49
50        L'acquisition et le parcours sont réalisés par la méthode
51        generator.gener(objet_mcfact)
52
53        L'écriture du fichier au format ini par appel de la méthode
54        generator.writefile(nom_fichier)
55
56        Ses caractéristiques principales sont exposées dans des attributs 
57        de classe :
58           - extensions : qui donne une liste d'extensions de fichier préconisées
59
60    """
61    # Les extensions de fichier préconisées
62    extensions=('.py','.comm')
63
64    def __init__(self,cr=None):
65       # Si l'objet compte-rendu n'est pas fourni, on utilise le compte-rendu standard
66       if cr :
67          self.cr=cr
68       else:
69          self.cr=N_CR.CR(debut='CR generateur format ini',
70                          fin='fin CR format ini')
71       # Le texte au format pyth est stocké dans l'attribut text
72       self.text=''
73
74    def writefile(self,filename):
75       fp=open(filename,'w')
76       fp.write(self.text)
77       fp.close()
78
79    def gener(self,obj,format='standard'):
80       """
81          Tous les mots-clés simples du niveau haut sont transformés en variables 
82
83          Tous les mots-clés facteurs sont convertis en dictionnaires
84
85          Les mots-clés multiples ne sont pas traités
86       """
87       s=''
88       for mocle in obj.mc_liste:
89          if isinstance(mocle,MCFACT):
90             valeur=self.generMCFACT(mocle)
91             s=s+"%s = %s\n" % (mocle.nom,valeur)
92          elif isinstance(v,MCSIMP):
93             valeur = self.generMCSIMP(mocle)
94             s=s+"%s = %s\n" % (mocle.nom,valeur)
95          else:
96             self.cr.fatal("Entite inconnue ou interdite : "+`mocle`)
97       self.text=s
98       return self.text
99
100    def generMCFACT(self,obj):
101       """
102          Cette méthode convertit un mot-clé facteur 
103          en une chaine de caractères représentative d'un dictionnaire
104       """
105       s = '{'
106       for mocle in obj.mc_liste:
107          if isinstance(mocle,MCSIMP):
108             valeur = self.generMCSIMP(mocle)
109             s=s+"'%s' : %s,\n" % (mocle.nom,valeur)
110          elif isinstance(mocle,MCFACT):
111             valeur=self.generMCFACT(mocle)
112             s=s+"'%s' : %s,\n" % (mocle.nom,valeur)
113          else:
114             self.cr.fatal("Entite inconnue ou interdite : "+`mocle`+" Elle est ignorée")
115       s=s+'}'
116       return s
117
118    def generMCSIMP(self,obj):
119       """
120          Cette méthode convertit un mot-clé simple en une chaine de caractères
121          au format pyth
122       """
123       try:
124          s="%s" % obj.valeur
125       except Exception,e :
126          self.cr.fatal("Type de valeur non supporté par le format pyth : "+ obj.nom + '\n'+str(e))
127          s="ERREUR"
128       return s
129