]> SALOME platform Git repositories - tools/eficas.git/blob - Validation/V_MCFACT.py
Salome HOME
*** empty log message ***
[tools/eficas.git] / Validation / V_MCFACT.py
1 #@ MODIF V_MCFACT Validation  DATE 07/09/2009   AUTEUR COURTOIS M.COURTOIS 
2 # -*- coding: iso-8859-1 -*-
3 # RESPONSABLE COURTOIS M.COURTOIS
4 #            CONFIGURATION MANAGEMENT OF EDF VERSION
5 # ======================================================================
6 # COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
7 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
8 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
9 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR   
10 # (AT YOUR OPTION) ANY LATER VERSION.                                 
11 #
12 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT 
13 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF          
14 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU    
15 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.                            
16 #
17 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE   
18 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,       
19 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.      
20 #                                                                       
21 #                                                                       
22 # ======================================================================
23
24
25 """
26    Ce module contient la classe mixin MCFACT qui porte les méthodes
27    nécessaires pour réaliser la validation d'un objet de type MCFACT
28    dérivé de OBJECT.
29
30    Une classe mixin porte principalement des traitements et est
31    utilisée par héritage multiple pour composer les traitements.
32 """
33 # Modules Python
34 import string
35
36 # Modules EFICAS
37 import V_MCCOMPO
38
39 class MCFACT(V_MCCOMPO.MCCOMPO):
40    """
41       Cette classe a un attribut de classe :
42
43       - txt_nat qui sert pour les comptes-rendus liés à cette classe
44    """
45
46    txt_nat="Mot cle Facteur :"
47
48    def isvalid(self,sd='oui',cr='non'):
49       """ 
50          Methode pour verifier la validité du MCFACT. Cette méthode
51          peut etre appelée selon plusieurs modes en fonction de la valeur
52          de sd et de cr.
53
54          Si cr vaut oui elle crée en plus un compte-rendu
55          sd est présent pour compatibilité de l'interface mais ne sert pas
56       """
57       if self.state == 'unchanged' :
58         return self.valid
59       else:
60         valid = 1
61         if hasattr(self,'valid'):
62           old_valid = self.valid
63         else:
64           old_valid = None
65         for child in self.mc_liste :
66           if not child.isvalid():
67             valid = 0
68             break
69         # Après avoir vérifié la validité de tous les sous-objets, on vérifie
70         # la validité des règles
71         text_erreurs,test_regles = self.verif_regles()
72         if not test_regles :
73           if cr == 'oui' : self.cr.fatal(string.join(("Règle(s) non respectée(s) :", text_erreurs)))
74           valid = 0
75         #
76         # On verifie les validateurs s'il y en a
77         #
78         if self.definition.validators and not self.definition.validators.verif(self.valeur):
79            if cr == 'oui' :
80               self.cr.fatal(string.join(("Mot-clé : ",self.nom,"devrait avoir ",self.definition.validators.info())))
81            valid=0
82         # fin des validateurs
83         #
84         if self.reste_val != {}:
85           if cr == 'oui' :
86             self.cr.fatal("Mots cles inconnus :" + string.join(self.reste_val.keys(),','))
87           valid=0
88         self.valid = valid
89         self.state = 'unchanged'
90         if not old_valid or old_valid != self.valid : 
91            self.init_modif_up()
92         return self.valid
93