1 #@ MODIF V_JDC Validation 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 mixin JDC qui porte les méthodes
26 nécessaires pour réaliser la validation d'un objet de type JDC
29 Une classe mixin porte principalement des traitements et est
30 utilisée par héritage multiple pour composer les traitements.
37 from Noyau.N_Exception import AsException
38 from Noyau.N_utils import AsType
40 class JDC(V_MCCOMPO.MCCOMPO):
46 Methode pour generation d un rapport de validite
49 self.cr.debut="DEBUT CR validation : "+self.nom
50 self.cr.fin="FIN CR validation :"+self.nom
51 for e in self.etapes :
53 self.cr.add(e.report())
54 self.state = 'modified'
55 self.isvalid(cr='oui')
58 def isvalid(self,cr='non'):
60 Méthode booléenne qui retourne 0 si le JDC est invalide, 1 sinon
62 # FR : on prend en compte l'état du JDC ('unchanged','modified','undetermined')
63 # afin d'accélérer le test de validité du JDC
64 if self.state == 'unchanged':
68 texte,test = self.verif_regles()
70 if cr == 'oui': self.cr.fatal(string.strip(texte))
74 if not e.isactif() : continue
78 self.state="unchanged"
82 def verif_regles(self):
84 Effectue la vérification de validité des règles du jeu de commandes
86 l_noms_etapes=self.get_l_noms_etapes()
89 for regle in self.regles :
90 texte,test = regle.verif(l_noms_etapes)
91 texte_global = texte_global + texte
92 test_global = test_global*test
93 return texte_global,test_global
95 def get_l_noms_etapes(self):
97 Retourne la liste des noms des étapes de self
100 for etape in self.etapes: