1 #@ MODIF N_PROC_ETAPE Noyau DATE 14/09/2004 AUTEUR MCOURTOI M.COURTOIS
2 # -*- coding: iso-8859-1 -*-
3 # CONFIGURATION MANAGEMENT OF EDF VERSION
4 # ======================================================================
5 # COPYRIGHT (C) 1991 - 2002 EDF R&D WWW.CODE-ASTER.ORG
6 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
7 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
8 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
9 # (AT YOUR OPTION) ANY LATER VERSION.
11 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
12 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
13 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
14 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
16 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
17 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
18 # 1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
21 # ======================================================================
25 Ce module contient la classe PROC_ETAPE qui sert à vérifier et à exécuter
30 import types,sys,string
34 import N_MCCOMPO, N_ETAPE
35 from N_Exception import AsException
38 class PROC_ETAPE(N_ETAPE.ETAPE):
40 Cette classe hérite de ETAPE. La seule différence porte sur le fait
41 qu'une procédure n'a pas de concept produit
45 def __init__(self,oper=None,args={}):
49 - definition : objet portant les attributs de définition d'une étape de type opérateur. Il
50 est initialisé par l'argument oper.
52 - valeur : arguments d'entrée de type mot-clé=valeur. Initialisé avec l'argument args.
58 self.parent=CONTEXT.get_current_step()
61 self.idracine=oper.label
62 self.appel=N_utils.callee_where()
68 def make_register(self):
70 Initialise les attributs jdc, id, niveau et réalise les enregistrements
74 self.jdc = self.parent.get_jdc_root()
75 self.id=self.parent.register(self)
78 self.jdc = self.parent =None
84 Demande la construction des sous-objets et les stocke dans l'attribut
87 self.mc_liste=self.build_mc()
91 Cette methode applique la fonction op_init au contexte du parent
92 et lance l'exécution en cas de traitement commande par commande
93 Elle doit retourner le concept produit qui pour une PROC est toujours None
94 En cas d'erreur, elle leve une exception : AsException ou EOFError
96 if not self.isactif():return
99 if type(self.definition.op_init) == types.FunctionType:
100 apply(self.definition.op_init,(self,self.parent.g_context))
103 except AsException,e:
104 raise AsException("Etape ",self.nom,'ligne : ',self.appel[0],
105 'fichier : ',self.appel[1],e)
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',
119 Méthode qui supprime toutes les références arrières afin que l'objet puisse
120 etre correctement détruit par le garbage collector
122 N_MCCOMPO.MCCOMPO.supprime(self)
126 def accept(self,visitor):
128 Cette methode permet de parcourir l'arborescence des objets
129 en utilisant le pattern VISITEUR
131 visitor.visitPROC_ETAPE(self)
133 def update_context(self,d):
135 Met à jour le contexte de l'appelant passé en argument (d)
136 Une PROC_ETAPE n ajoute pas directement de concept dans le contexte
137 Seule une fonction enregistree dans op_init pourrait le faire
139 if type(self.definition.op_init) == types.FunctionType:
140 apply(self.definition.op_init,(self,d))