1 #@ MODIF V_JDC Validation DATE 29/05/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 mixin JDC qui porte les méthodes
23 nécessaires pour réaliser la validation d'un objet de type JDC
26 Une classe mixin porte principalement des traitements et est
27 utilisée par héritage multiple pour composer les traitements.
34 from Noyau.N_Exception import AsException
35 from Noyau.N_utils import AsType
37 class JDC(V_MCCOMPO.MCCOMPO):
43 Methode pour generation d un rapport de validite
46 self.cr.debut="DEBUT CR validation : "+self.nom
47 self.cr.fin="FIN CR validation :"+self.nom
48 for e in self.etapes :
50 self.cr.add(e.report())
51 self.state = 'modified'
52 self.isvalid(cr='oui')
55 def isvalid(self,cr='non'):
57 Méthode booléenne qui retourne 0 si le JDC est invalide, 1 sinon
59 # FR : on prend en compte l'état du JDC ('unchanged','modified','undetermined')
60 # afin d'accélérer le test de validité du JDC
61 if self.state == 'unchanged':
65 texte,test = self.verif_regles()
67 if cr == 'oui': self.cr.fatal(string.strip(texte))
71 if not e.isactif() : continue
78 def verif_regles(self):
80 Effectue la vérification de validité des règles du jeu de commandes
82 l_noms_etapes=self.get_l_noms_etapes()
85 for regle in self.regles :
86 texte,test = regle.verif(l_noms_etapes)
87 texte_global = texte_global + texte
88 test_global = test_global*test
89 return texte_global,test_global
91 def get_l_noms_etapes(self):
93 Retourne la liste des noms des étapes de self
96 for etape in self.etapes: