1 #@ MODIF N_PROC_ETAPE Noyau DATE 27/03/2002 AUTEUR DURAND C.DURAND
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 la classe PROC_ETAPE qui sert à vérifier et à exécuter
27 import types,sys,string
31 import N_MCCOMPO, N_ETAPE
32 from N_Exception import AsException
35 class PROC_ETAPE(N_ETAPE.ETAPE):
37 Cette classe hérite de ETAPE. La seule différence porte sur le fait
38 qu'une procédure n'a pas de concept produit
42 def __init__(self,oper=None,args={}):
46 - definition : objet portant les attributs de définition d'une étape de type opérateur. Il
47 est initialisé par l'argument oper.
49 - valeur : arguments d'entrée de type mot-clé=valeur. Initialisé avec l'argument args.
55 self.parent=CONTEXT.get_current_step()
58 self.idracine=oper.label
59 self.appel=N_utils.callee_where()
65 def make_register(self):
67 Initialise les attributs jdc, id, niveau et réalise les enregistrements
71 self.jdc = self.parent.get_jdc_root()
72 self.id=self.parent.register(self)
75 self.jdc = self.parent =None
81 Demande la construction des sous-objets et les stocke dans l'attribut
84 self.mc_liste=self.build_mc()
88 Cette methode applique la fonction op_init au contexte du parent
89 et lance l'exécution en cas de traitement commande par commande
90 Elle doit retourner le concept produit qui pour une PROC est toujours None
91 En cas d'erreur, elle leve une exception : AsException ou EOFError
93 if not self.isactif():return
96 if type(self.definition.op_init) == types.FunctionType:
97 apply(self.definition.op_init,(self,self.parent.g_context))
100 if self.jdc.par_lot == "NON" :
102 except AsException,e:
103 raise AsException("Etape ",self.nom,'ligne : ',self.appel[0],
104 'fichier : ',self.appel[1],e)
106 self.reset_current_step()
109 l=traceback.format_exception(sys.exc_info()[0],sys.exc_info()[1],sys.exc_info()[2])
110 raise AsException("Etape ",self.nom,'ligne : ',self.appel[0],
111 'fichier : ',self.appel[1]+'\n',
116 Méthode qui supprime toutes les références arrières afin que l'objet puisse
117 etre correctement détruit par le garbage collector
119 N_MCCOMPO.MCCOMPO.supprime(self)
123 def accept(self,visitor):
125 Cette methode permet de parcourir l'arborescence des objets
126 en utilisant le pattern VISITEUR
128 visitor.visitPROC_ETAPE(self)
130 def update_context(self,d):
132 Met à jour le contexte de l'appelant passé en argument (d)
133 Une PROC_ETAPE n ajoute pas directement de concept dans le contexte
134 Seule une fonction enregistree dans op_init pourrait le faire
136 if type(self.definition.op_init) == types.FunctionType:
137 apply(self.definition.op_init,(self,d))