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.
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.
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.
19 # ======================================================================
21 Ce module contient le plugin generateur de fichier au format pyth pour EFICAS.
28 from Noyau import N_CR
29 from Accas import MCSIMP,MCFACT
33 Retourne les informations nécessaires pour le chargeur de plugins
35 Ces informations sont retournées dans un dictionnaire
40 # La factory pour créer une instance du plugin
41 'factory' : PythGenerator,
47 Ce generateur parcourt un objet de type MCFACT et produit
48 un fichier au format pyth
50 L'acquisition et le parcours sont réalisés par la méthode
51 generator.gener(objet_mcfact)
53 L'écriture du fichier au format ini par appel de la méthode
54 generator.writefile(nom_fichier)
56 Ses caractéristiques principales sont exposées dans des attributs
58 - extensions : qui donne une liste d'extensions de fichier préconisées
61 # Les extensions de fichier préconisées
62 extensions=('.py','.comm')
64 def __init__(self,cr=None):
65 # Si l'objet compte-rendu n'est pas fourni, on utilise le compte-rendu standard
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
74 def writefile(self,filename):
79 def gener(self,obj,format='standard'):
81 Tous les mots-clés simples du niveau haut sont transformés en variables
83 Tous les mots-clés facteurs sont convertis en dictionnaires
85 Les mots-clés multiples ne sont pas traité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)
96 self.cr.fatal("Entite inconnue ou interdite : "+`mocle`)
100 def generMCFACT(self,obj):
102 Cette méthode convertit un mot-clé facteur
103 en une chaine de caractères représentative d'un dictionnaire
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)
114 self.cr.fatal("Entite inconnue ou interdite : "+`mocle`+" Elle est ignorée")
118 def generMCSIMP(self,obj):
120 Cette méthode convertit un mot-clé simple en une chaine de caractères
126 self.cr.fatal("Type de valeur non supporté par le format pyth : "+ obj.nom + '\n'+str(e))