10 class ETAPE(I_MCCOMPO.MCCOMPO):
20 Retourne l'attribut fr de self.definition
23 return self.definition.fr
28 if CONTEXT.debug : print "SDNAME ",self.reuse,self.sd,self.sd.get_name()
29 if self.reuse != None:
30 sdname= self.reuse.get_name()
32 sdname=self.sd.get_name()
33 if string.find(sdname,'sansnom') != -1 or string.find(sdname,'SD_') != -1:
34 # dans le cas où la SD est 'sansnom' ou 'SD_' on retourne la chaîne vide
38 def is_reentrant(self):
40 Indique si la commande est reentrante
42 return self.definition.reentrant == 'o'
46 Met l'état de l'étape à : modifié
47 Propage la modification au parent
48 Si la fonction op_init existe, l'active
51 # doit etre realisée apres init_modif et la validite reevaluée
52 # apres cette action. L'état modified de tous les objets doit etre
54 self.state = 'modified'
56 self.parent.init_modif()
60 Méthode appelée une fois qu'une modification a été faite afin de
61 déclencher d'éventuels traitements post-modification
62 ex : INCLUDE et POURSUITE
65 if type(self.definition.op_init) == types.FunctionType :
66 # XXX Normalement en mode editeur g_context ne peut pas etre utilisé
67 apply(self.definition.op_init,(self,self.parent.g_context))
68 self.state = 'modified'
70 def nomme_sd(self,nom) :
72 Cette méthode a pour fonction de donner un nom (nom) au concept
73 produit par l'étape (self).
74 - si le concept n'existe pas, on essaye de le créer (à condition que l'étape soit valide ET non réentrante)
75 - si il existe déjà, on le renomme et on répercute les changements dans les autres étapes
76 Les valeurs de retour sont :
77 0 si le nommage n'a pas pu etre mené à son terme,
78 1 dans le cas contraire
80 if len(nom) > 8 and self.jdc.definition.code == 'ASTER':
81 return 0,"Nom de concept trop long (maxi 8 caractères)"
83 # Cas particulier des opérateurs réentrants
84 if not self.isvalid(sd='non') : return 0,"Nommage du concept refusé : l'opérateur n'est pas valide"
85 if self.definition.reentrant == 'o':
86 self.sd = self.reuse = self.jdc.get_sdprod(nom)
88 return 1,"Concept existant"
90 return 0,"Opérateur réentrant mais concept non existant"
91 if self.definition.reentrant == 'f' :
92 sd = self.jdc.get_sd_avant_etape(nom,self)
94 self.sd = self.reuse = sd
95 return 1,"Opérateur facultativement réentrant et concept existant trouvé"
97 # il faut éventuellement enlever le lien vers une SD existante car si on passe ici
98 # cela signifie que l'opérateur n'est pas utilisé en mode réentrant.
99 # Si on ne fait pas cela, le nom de l'opérateur réutilisé est aussi modifié
100 # et on ne peut plus modifier la SD de l'opérateur
102 self.sd = self.reuse = None
103 # l'opérateur n'est pas réentrant ou facultativement reentrant mais pas dans ce cas
105 if self.parent.get_sd_autour_etape(nom,self):
106 # On force self.valid a 0 car l appel a isvalid precedent l a mis a 1
107 # mais ceci indique seulement une validité partielle
108 # isvalid ne devrait peut etre pas mettre l attribut valid à 1 si sd == 'non'
110 return 0,"Nommage du concept refuse : un concept de meme nom existe deja"
111 # Il n'existe pas de sd de nom sdnom. On peut donc créer le concept retourné.
112 # Il est créé sans nom mais enregistré dans la liste des concepts existants
115 return 1,"Nommage du concept effectué"
118 if string.find(old_nom,'sansnom') :
119 # Dans le cas où old_nom == sansnom, isvalid retourne 0 alors que ...
120 # par contre si le concept existe et qu'il s'appelle sansnom c'est que l'étape est valide
121 # on peut donc le nommer sans test préalable
123 return 1,"Nommage du concept effectué"
125 # Normalement l appel de isvalid a mis a jour le concept produit (son type)
126 # Il suffit de spécifier l attribut nom de sd pour le nommer si le nom n est pas
128 if self.parent.get_sd_autour_etape(nom,self):
129 return 0,"Nommage du concept refuse : un concept de meme nom existe deja"
132 return 1,"Nommage du concept effectué"
134 # Normalement on ne devrait pas passer ici
135 return 0,'Normalement on ne devrait pas passer ici'
137 def get_sdprods(self,nom_sd):
139 Fonction : retourne le concept produit par l etape de nom nom_sd
140 s il existe sinon None
143 if self.sd.nom == nom_sd:return self.sd
147 Rend l'etape courante active.
148 Il faut ajouter la sd si elle existe au contexte global du JDC
152 if not self.sd : return
153 # XXX Pourquoi faut-il faire ce qui suit ??? par defaut les etapes sont actives
155 self.jdc.append_sdprod(self.sd)
161 Rend l'etape courante inactive
162 Il faut supprimer la sd du contexte global du JDC
163 et de la liste des sd
166 if not self.sd : return
167 self.jdc.del_sdprod(self.sd)
168 self.jdc.delete_concept_after_etape(self,self.sd)
170 def supprime_sdprods(self):
173 Lors d'une destruction d'etape, detruit tous les concepts produits
174 Un opérateur n a qu un concept produit
175 Une procedure n'en a aucun
176 Une macro en a en général plus d'un
178 # XXX pour les macros il faudrait peut etre aussi
179 # supprimer les concepts a droite du = ???
180 if not self.is_reentrant() :
181 # l'étape n'est pas réentrante
182 # le concept retourné par l'étape est à supprimer car il était
185 self.parent.del_sdprod(self.sd)
186 self.parent.delete_concept(self.sd)
188 def delete_concept(self,sd):
193 Mettre a jour les mots cles de l etape et eventuellement
194 le concept produit si reuse
195 suite à la disparition du concept sd
196 Seuls les mots cles simples MCSIMP font un traitement autre
197 que de transmettre aux fils
199 if self.reuse and self.reuse == sd:
200 self.sd=self.reuse=None
202 for child in self.mc_liste :
203 child.delete_concept(sd)
205 def make_register(self):
207 Initialise les attributs jdc, id, niveau et réalise les
208 enregistrements nécessaires
209 Pour EFICAS, on tient compte des niveaux
212 self.jdc = self.parent.get_jdc_root()
213 self.id= self.parent.register(self)
214 if self.definition.niveau :
215 # La définition est dans un niveau. En plus on
216 # l'enregistre dans le niveau
217 self.nom_niveau_definition = self.definition.niveau.nom
218 self.niveau = self.parent.dict_niveaux[self.nom_niveau_definition]
219 self.niveau.register(self)
221 # La définition est au niveau global
222 self.nom_niveau_definition = 'JDC'
223 self.niveau=self.parent
225 self.jdc = self.parent =None
230 """ Méthode qui retourne une copie de self non enregistrée auprès du JDC
235 etape.state = 'modified'
240 for objet in self.mc_liste:
241 new_obj = objet.copy()
242 new_obj.reparent(etape)
243 etape.mc_liste.append(new_obj)
246 def get_noms_sd_oper_reentrant(self):
248 Retourne la liste des noms de concepts utilisés à l'intérieur de la commande
249 qui sont du type que peut retourner cette commande
251 liste_sd = self.get_sd_utilisees()
253 if type(self.definition.sd_prod) == types.FunctionType:
254 d=self.cree_dict_valeurs(self.mc_liste)
256 classe_sd_prod = apply(self.definition.sd_prod,(),d)
260 classe_sd_prod = self.definition.sd_prod
262 if sd.__class__ is classe_sd_prod : l_noms.append(sd.nom)
266 def get_sd_utilisees(self):
268 Retourne la liste des concepts qui sont utilisés à l'intérieur d'une commande
269 ( comme valorisation d'un MCS)
272 for child in self.mc_liste:
273 l.extend(child.get_sd_utilisees())
276 def get_genealogie(self):
278 Retourne la liste des noms des ascendants de l'objet self
279 en s'arretant à la première ETAPE rencontrée
283 def reparent(self,parent):
285 Cette methode sert a reinitialiser la parente de l'objet
288 self.jdc=parent.get_jdc_root()
290 for mocle in self.mc_liste:
293 def verif_existence_sd(self):
295 Vérifie que les structures de données utilisées dans self existent bien dans le contexte
296 avant étape, sinon enlève la référence à ces concepts
298 for motcle in self.mc_liste :
299 motcle.verif_existence_sd()