Salome HOME
modif pour MT
[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 - 2017  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 methodes
25    necessaires pour realiser la validation d'un objet de type MCList
26    derive de OBJECT.
27
28    Une classe mixin porte principalement des traitements et est
29    utilisee par heritage multiple pour composer les traitements.
30 """
31 # Modules Python
32 from __future__ import print_function
33 from __future__ import absolute_import
34 try : 
35   from builtins import object
36 except : pass
37
38 import traceback
39
40 # Modules EFICAS
41 from Extensions.i18n import tr
42 from Noyau import MAXSIZE, MAXSIZE_MSGCHK
43 from Noyau import N_CR
44 from Noyau.N_Exception import AsException
45
46
47 class MCList(object):
48
49     """
50        Cette classe a deux attributs de classe :
51
52        - CR qui sert a construire l'objet compte-rendu
53
54        - txt_nat qui sert pour les comptes-rendus lies a cette classe
55     """
56
57     CR = N_CR.CR
58     txt_nat = "Mot cle Facteur Multiple :"
59
60     def isValid(self, cr='non'):
61         """
62            Methode pour verifier la validite du MCList. Cette methode
63            peut etre appelee selon plusieurs modes en fonction de la valeur
64            de cr.
65
66            Si cr vaut oui elle cree en plus un compte-rendu.
67
68            On n'utilise pas d'attribut pour stocker l'etat et on ne remonte pas
69            le changement d'etat au parent (pourquoi ??)
70            MCLIST est une liste de MCFACT. Les MCFACT ont le meme parent
71            que le MCLIST qui les contient. Il n'est donc pas necessaire de
72            remonter le changement d'etat au parent. C'est deja fait
73            par les MCFACT.
74         """
75         if len(self.data) == 0:
76             return 0
77
78         valid = 1
79         definition = self.data[0].definition
80         # Verification du nombre des mots cles facteurs
81         if definition.min is not None and len(self.data) < definition.min:
82             valid = 0
83             if cr == 'oui':
84                 self.cr.fatal( "Nombre de mots cles facteurs insuffisant minimum : %s" % definition.min)
85
86         if definition.max is not None and len(self.data) > definition.max:
87             valid = 0
88             if cr == 'oui':
89                 self.cr.fatal(
90                     "Nombre de mots cles facteurs trop grand maximum : %s" % definition.max)
91         num = 0
92         for i in self.data:
93             num = num + 1
94             if not i.isValid():
95                 valid = 0
96                 if cr == 'oui' and len(self) > 1:
97                     self.cr.fatal( "L'occurrence numero %d du mot-cle facteur : %s n'est pas valide" % (num, self.nom))
98         return valid
99
100     def report(self):
101         """
102             Genere le rapport de validation de self
103         """
104         if len(self) > 1:
105             # Mot cle facteur multiple
106             self.cr = self.CR( debut="Mot-cle facteur multiple : " + tr(self.nom),
107                 fin="Fin Mot-cle facteur multiple : " + tr(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="Mot-cle facteur : " + tr(self.nom) ,
120                             fin="Fin Mot-cle facteur : " + tr(self.nom))
121
122         try:
123             self.isValid(cr='oui')
124         except AsException as e:
125             if CONTEXT.debug:
126                 traceback.print_exc()
127             self.cr.fatal(" %s Mot-cle facteur multiple : %s" %( self.nom, e))
128         return self.cr