1 # -*- coding: utf-8 -*-
2 #@ MODIF N_PROC_ETAPE Noyau DATE 26/09/2003 AUTEUR DURAND C.DURAND
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 # ======================================================================
23 Ce module contient la classe PROC_ETAPE qui sert à vérifier et à exécuter
28 import types,sys,string
32 import N_MCCOMPO, N_ETAPE
33 from N_Exception import AsException
36 class PROC_ETAPE(N_ETAPE.ETAPE):
38 Cette classe hérite de ETAPE. La seule différence porte sur le fait
39 qu'une procédure n'a pas de concept produit
43 def __init__(self,oper=None,args={}):
47 - definition : objet portant les attributs de définition d'une étape de type opérateur. Il
48 est initialisé par l'argument oper.
50 - valeur : arguments d'entrée de type mot-clé=valeur. Initialisé avec l'argument args.
56 self.parent=CONTEXT.get_current_step()
59 self.idracine=oper.label
60 self.appel=N_utils.callee_where()
66 def make_register(self):
68 Initialise les attributs jdc, id, niveau et réalise les enregistrements
72 self.jdc = self.parent.get_jdc_root()
73 self.id=self.parent.register(self)
76 self.jdc = self.parent =None
82 Demande la construction des sous-objets et les stocke dans l'attribut
85 self.mc_liste=self.build_mc()
89 Cette methode applique la fonction op_init au contexte du parent
90 et lance l'exécution en cas de traitement commande par commande
91 Elle doit retourner le concept produit qui pour une PROC est toujours None
92 En cas d'erreur, elle leve une exception : AsException ou EOFError
94 if not self.isactif():return
97 if type(self.definition.op_init) == types.FunctionType:
98 apply(self.definition.op_init,(self,self.parent.g_context))
101 except AsException,e:
102 raise AsException("Etape ",self.nom,'ligne : ',self.appel[0],
103 'fichier : ',self.appel[1],e)
107 l=traceback.format_exception(sys.exc_info()[0],sys.exc_info()[1],sys.exc_info()[2])
108 raise AsException("Etape ",self.nom,'ligne : ',self.appel[0],
109 'fichier : ',self.appel[1]+'\n',
117 Méthode qui supprime toutes les références arrières afin que l'objet puisse
118 etre correctement détruit par le garbage collector
120 N_MCCOMPO.MCCOMPO.supprime(self)
124 def accept(self,visitor):
126 Cette methode permet de parcourir l'arborescence des objets
127 en utilisant le pattern VISITEUR
129 visitor.visitPROC_ETAPE(self)
131 def update_context(self,d):
133 Met à jour le contexte de l'appelant passé en argument (d)
134 Une PROC_ETAPE n ajoute pas directement de concept dans le contexte
135 Seule une fonction enregistree dans op_init pourrait le faire
137 if type(self.definition.op_init) == types.FunctionType:
138 apply(self.definition.op_init,(self,d))