Salome HOME
AY a ajouté l'interception de l'exception levée lorsque la chaine passée
[tools/eficas.git] / Extensions / etape_niveau.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 la classe ETAPE_NIVEAU qui sert à 
22     concrétiser les niveaux au sein d'un JDC
23 """
24 import traceback
25
26 from Noyau import N_OBJECT
27 import prefs
28
29 class ETAPE_NIVEAU(N_OBJECT.OBJECT):
30
31   def __init__(self,niveau,parent):
32     self.parent = parent
33     self.jdc = self.parent.get_jdc_root()
34     self.niveau = self
35     self.definition = niveau
36     self.etapes=[]
37     self.etapes_niveaux = []
38     self.dict_niveaux={}
39     self.editmode = 0
40     self.state="undetermined"
41     self.build_niveaux()
42
43   def build_niveaux(self):
44     for niveau in self.definition.l_niveaux:
45       etape_niveau = ETAPE_NIVEAU(niveau,self)
46       self.etapes_niveaux.append(etape_niveau)
47       self.dict_niveaux[niveau.nom]=etape_niveau
48
49   def register(self,etape):
50     """ 
51           Enregistre la commande étape :
52           - si editmode = 0 : on est en mode relecture d'un fichier de commandes
53           auquel cas on ajoute etape à la fin de la liste self.etapes
54           - si editmode = 1 : on est en mode ajout d'étape depuis eficas auquel cas
55           cette méthode ne fait rien, c'est addentité qui enregistre etape
56           à la bonne place dans self.etapes 
57     """
58     if self.editmode : return
59     self.etapes.append(etape)
60
61   def unregister(self,etape):
62     """
63         Desenregistre l'etape du niveau
64     """
65     self.etapes.remove(etape)
66
67   def ident(self):
68     return self.definition.label
69
70   def isactif(self):
71     #print 'Niveau : ',self.definition.nom
72     #print '\tactif =',self.definition.actif
73     if self.definition.actif == 1 :
74       return 1
75     else :
76       # self.actif est une condition à évaluer dans un certain contexte ...
77       d = self.cree_dict_valeurs()
78       try:
79         t=eval(self.definition.actif,d)
80         return t
81       except:
82         traceback.print_exc()
83         return 0
84
85   def cree_dict_valeurs(self):
86     """
87     Retourne le dictionnaire des frères aînés de self composé des couples :
88     {nom_frère isvalid()}
89     """
90     d={}
91     for niveau in self.parent.etapes_niveaux:
92       if niveau is self : break
93       d[niveau.definition.nom]=niveau.isvalid()
94     return d
95
96   def isvalid(self):
97     """ Méthode booléenne qui retourne 0 si le niveau est invalide, 1 sinon """
98     if self.etapes_niveaux == []:
99       if len(self.etapes) == 0:
100         return self.definition.valide_vide
101       else:
102         for etape in self.etapes :
103           if not etape.isvalid() : return 0
104         return 1
105     else:
106       for etape_niveau in self.etapes_niveaux :
107         if not etape_niveau.isvalid() : return 0
108       return 1
109
110   def accept(self,visitor):
111     visitor.visitETAPE_NIVEAU(self)
112
113   def addentite(self,name,pos_rel):
114     self.editmode = 1
115     try :
116       pos_abs=self.jdc.get_nb_etapes_avant(self)+pos_rel
117       cmd = self.jdc.addentite(name,pos_abs)
118       self.etapes.insert(pos_rel,cmd)
119       self.editmode = 0
120       return cmd
121     except:
122       traceback.print_exc()
123       self.editmode = 0
124       return None
125
126   def suppentite(self,etape) :
127     """ Classe ETAPE_NIVEAU
128         Supprime une étape 
129     """
130     self.jdc.suppentite(etape)
131
132
133   def get_fr(self):
134      """
135         Retourne le texte d'aide dans la langue choisie
136      """
137      try :
138         return getattr(self.definition,prefs.lang)
139      except:
140         return ''
141