Salome HOME
1er mise en coherence avec la 7_6
[tools/eficas.git] / Validation / V_PROC_ETAPE.py
1 # coding=utf-8
2 # person_in_charge: mathieu.courtois at edf.fr
3 # ======================================================================
4 # COPYRIGHT (C) 1991 - 2015  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    Ce module contient la classe mixin PROC_ETAPE qui porte les méthodes
22    nécessaires pour réaliser la validation d'un objet de type PROC_ETAPE
23    dérivé de OBJECT.
24
25    Une classe mixin porte principalement des traitements et est
26    utilisée par héritage multiple pour composer les traitements.
27 """
28 # Modules EFICAS
29 import V_ETAPE
30 from Noyau.N_Exception import AsException
31 from Noyau.N_utils import AsType
32 from Noyau.strfunc import ufmt
33
34
35 class PROC_ETAPE(V_ETAPE.ETAPE):
36
37     """
38        On réutilise les méthodes report,verif_regles
39        de ETAPE par héritage.
40     """
41
42     def isvalid(self, sd='oui', cr='non'):
43         """
44            Methode pour verifier la validité de l'objet PROC_ETAPE. Cette méthode
45            peut etre appelée selon plusieurs modes en fonction de la valeur
46            de sd et de cr (sd n'est pas utilisé).
47
48            Si cr vaut oui elle crée en plus un compte-rendu.
49
50            Cette méthode a plusieurs fonctions :
51
52             - retourner un indicateur de validité 0=non, 1=oui
53
54             - produire un compte-rendu : self.cr
55
56             - propager l'éventuel changement d'état au parent
57         """
58         if CONTEXT.debug:
59             print "ETAPE.isvalid ", self.nom
60         if self.state == 'unchanged':
61             return self.valid
62         else:
63             valid = self.valid_child()
64             valid = valid * self.valid_regles(cr)
65             if self.reste_val != {}:
66                 if cr == 'oui':
67                     self.cr.fatal(
68                         _(u"Mots clés inconnus : %s"), ','.join(self.reste_val.keys()))
69                 valid = 0
70             self.set_valid(valid)
71             return self.valid