Salome HOME
bug
[tools/eficas.git] / Validation / V_MCLIST.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
22
23 """
24    Ce module contient la classe mixin MCList qui porte les méthodes
25    nécessaires pour réaliser la validation d'un objet de type MCList
26    dérivé de OBJECT.
27
28    Une classe mixin porte principalement des traitements et est
29    utilisée par héritage multiple pour composer les traitements.
30 """
31 # Modules Python
32 import traceback
33
34 # Modules EFICAS
35 from Noyau import MAXSIZE, MAXSIZE_MSGCHK
36 from Noyau import N_CR
37 from Noyau.N_Exception import AsException
38 from Noyau.strfunc import ufmt
39
40
41 class MCList:
42
43     """
44        Cette classe a deux attributs de classe :
45
46        - CR qui sert à construire l'objet compte-rendu
47
48        - txt_nat qui sert pour les comptes-rendus liés à cette classe
49     """
50
51     CR = N_CR.CR
52     txt_nat = u"Mot clé Facteur Multiple :"
53
54     def isvalid(self, cr='non'):
55         """
56            Methode pour verifier la validité du MCList. Cette méthode
57            peut etre appelée selon plusieurs modes en fonction de la valeur
58            de cr.
59
60            Si cr vaut oui elle crée en plus un compte-rendu.
61
62            On n'utilise pas d'attribut pour stocker l'état et on ne remonte pas
63            le changement d'état au parent (pourquoi ??)
64            MCLIST est une liste de MCFACT. Les MCFACT ont le meme parent
65            que le MCLIST qui les contient. Il n'est donc pas necessaire de
66            remonter le changement d'etat au parent. C'est deja fait
67            par les MCFACT.
68         """
69         if len(self.data) == 0:
70             return 0
71
72         valid = 1
73         definition = self.data[0].definition
74         # Verification du nombre des mots cles facteurs
75         if definition.min is not None and len(self.data) < definition.min:
76             valid = 0
77             if cr == 'oui':
78                 self.cr.fatal(
79                     _(u"Nombre de mots clés facteurs insuffisant minimum : %s"),
80                     definition.min)
81
82         if definition.max is not None and len(self.data) > definition.max:
83             valid = 0
84             if cr == 'oui':
85                 self.cr.fatal(
86                     _(u"Nombre de mots clés facteurs trop grand maximum : %s"),
87                     definition.max)
88         num = 0
89         for i in self.data:
90             num = num + 1
91             if not i.isvalid():
92                 valid = 0
93                 if cr == 'oui' and len(self) > 1:
94                     self.cr.fatal(
95                         _(u"L'occurrence numéro %d du mot-clé facteur : %s n'est pas valide"),
96                         num, self.nom)
97         return valid
98
99     def report(self):
100         """
101             Génère le rapport de validation de self
102         """
103         if len(self) > 1:
104             # Mot cle facteur multiple
105             self.cr = self.CR(
106                 debut=u"Mot-clé facteur multiple : " + self.nom,
107                 fin=u"Fin Mot-clé facteur multiple : " + self.nom)
108             j = 0
109             for i in self.data:
110                 j += 1
111                 if j > MAXSIZE:
112                     print(MAXSIZE_MSGCHK.format(MAXSIZE, len(self.data)))
113                     break
114                 self.cr.add(i.report())
115         elif len(self) == 1:
116             # Mot cle facteur non multiple
117             self.cr = self.data[0].report()
118         else:
119             self.cr = self.CR(debut=u"Mot-clé facteur : " + self.nom,
120                               fin=u"Fin Mot-clé facteur : " + self.nom)
121
122         try:
123             self.isvalid(cr='oui')
124         except AsException, e:
125             if CONTEXT.debug:
126                 traceback.print_exc()
127             self.cr.fatal(_(u"Mot-clé facteur multiple : %s, %s"), self.nom, e)
128         return self.cr