Salome HOME
CCAR: ajout du repertoire Doc qui contient un Makefile pour générer une doc
[tools/eficas.git] / Validation / V_MCBLOC.py
1 #@ MODIF V_MCBLOC 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 MCBLOC qui porte les méthodes
23    nécessaires pour réaliser la validation d'un objet de type MCBLOC
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
31
32 # Modules EFICAS
33 import V_MCCOMPO
34
35 class MCBLOC(V_MCCOMPO.MCCOMPO):
36    """
37       Cette classe a un attribut de classe :
38           - txt_nat qui sert pour les comptes-rendus liés à cette classe
39    """
40
41    txt_nat="Bloc :"
42
43    def isvalid(self,sd='oui',cr='non'):
44       """ 
45          Methode pour verifier la validité du MCBLOC. Cette méthode
46          peut etre appelée selon plusieurs modes en fonction de la valeur
47          de sd et de cr.
48
49          Si cr vaut oui elle crée en plus un compte-rendu
50          sd est présent pour compatibilité de l'interface mais ne sert pas
51       """
52       if self.state == 'unchanged' :
53         return self.valid
54       else:
55         valid = 1
56         if hasattr(self,'valid'):
57           old_valid = self.valid
58         else:
59           old_valid = None
60         for child in self.mc_liste :
61           if not child.isvalid():
62             valid = 0
63             break
64         # Après avoir vérifié la validité de tous les sous-objets, on vérifie
65         # la validité des règles
66         text_erreurs,test_regles = self.verif_regles()
67         if not test_regles :
68           if cr == 'oui' : self.cr.fatal(string.join(("Règle(s) non respectée(s) :", text_erreurs)))
69           valid = 0
70         self.valid = valid
71         self.state = 'unchanged'
72         if not old_valid or old_valid != self.valid : 
73            self.init_modif_up()
74         return self.valid
75