]> SALOME platform Git repositories - tools/eficas.git/blob - Validation/V_PROC_ETAPE.py
Salome HOME
Version Aster 6.3.14
[tools/eficas.git] / Validation / V_PROC_ETAPE.py
1 #@ MODIF V_PROC_ETAPE Validation  DATE 27/03/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.                                 
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 PROC_ETAPE qui porte les méthodes
23    nécessaires pour réaliser la validation d'un objet de type PROC_ETAPE
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_ETAPE
34 from Noyau.N_Exception import AsException
35 from Noyau.N_utils import AsType
36
37 class PROC_ETAPE(V_ETAPE.ETAPE):
38    """
39       On réutilise les méthodes report,verif_regles 
40       de ETAPE par héritage.
41    """
42
43    def isvalid(self,sd='oui',cr='non'):
44       """ 
45          Methode pour verifier la validité de l'objet PROC_ETAPE. Cette méthode
46          peut etre appelée selon plusieurs modes en fonction de la valeur
47          de sd et de cr (sd n'est pas utilisé).
48
49          Si cr vaut oui elle crée en plus un compte-rendu.
50
51          Cette méthode a plusieurs fonctions :
52
53           - retourner un indicateur de validité 0=non, 1=oui
54
55           - produire un compte-rendu : self.cr
56
57           - propager l'éventuel changement d'état au parent
58
59       """
60       if CONTEXT.debug : print "ETAPE.isvalid ",self.nom
61       if self.state == 'unchanged' :
62         return self.valid
63       else:
64         valid = 1
65         if hasattr(self,'valid'):
66           old_valid = self.valid
67         else:
68           old_valid = None
69         # on teste les enfants
70         for child in self.mc_liste :
71           if not child.isvalid():
72             valid = 0
73             break
74         # on teste les règles de self
75         text_erreurs,test_regles = self.verif_regles()
76         if not test_regles :
77           if cr == 'oui' : self.cr.fatal(string.join(("Règle(s) non respectée(s) :", text_erreurs)))
78           valid = 0
79         if self.reste_val != {}:
80           if cr == 'oui' :
81             self.cr.fatal("Mots cles inconnus :" + string.join(self.reste_val.keys(),','))
82           valid=0
83         self.valid = valid
84         self.state = 'unchanged'
85         if old_valid:
86           if old_valid != self.valid : self.init_modif_up()
87         return self.valid
88
89