Salome HOME
PN pb avec les copier/coller
[tools/eficas.git] / Validation / V_JDC.py
1 #@ MODIF V_JDC Validation  DATE 26/09/2003   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.                                 
9 #
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.                            
14 #
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.      
18 #                                                                       
19 #                                                                       
20 # ======================================================================
21 """
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
24    dérivé de OBJECT.
25
26    Une classe mixin porte principalement des traitements et est
27    utilisée par héritage multiple pour composer les traitements.
28 """
29 # Modules Python
30 import string,types
31
32 # Modules EFICAS
33 import V_MCCOMPO
34 from Noyau.N_Exception import AsException
35 from Noyau.N_utils import AsType
36
37 class JDC(V_MCCOMPO.MCCOMPO):
38    """
39    """
40
41    def report(self):
42       """ 
43           Methode pour generation d un rapport de validite
44       """
45       self.cr.purge()
46       self.cr.debut="DEBUT CR validation : "+self.nom
47       self.cr.fin="FIN CR validation :"+self.nom
48       for e in self.etapes :
49         if e.isactif():
50           self.cr.add(e.report())
51       self.state = 'modified'
52       self.isvalid(cr='oui')
53       return self.cr
54
55    def isvalid(self,cr='non'):
56       """
57         Méthode booléenne qui retourne 0 si le JDC est invalide, 1 sinon
58       """
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':
62         return self.valid
63       else:
64         valid = 1
65         texte,test = self.verif_regles()
66         if test == 0:
67           if cr == 'oui': self.cr.fatal(string.strip(texte))
68           valid = 0
69         if valid :
70           for e in self.etapes:
71             if not e.isactif() : continue
72             if not e.isvalid():
73               valid = 0
74               break
75         self.state="unchanged"
76         self.valid = valid
77         return self.valid
78
79    def verif_regles(self):
80       """ 
81          Effectue la vérification de validité des règles du jeu de commandes 
82       """
83       l_noms_etapes=self.get_l_noms_etapes()
84       texte_global = ''
85       test_global = 1
86       for regle in self.regles :
87         texte,test = regle.verif(l_noms_etapes)
88         texte_global = texte_global + texte
89         test_global = test_global*test
90       return texte_global,test_global
91
92    def get_l_noms_etapes(self):
93       """ 
94           Retourne la liste des noms des étapes de self 
95       """
96       l=[]
97       for etape in self.etapes:
98         l.append(etape.nom)
99       return l
100