Salome HOME
legere difference ds VARIABLES_TO_BE...
[tools/eficas.git] / Validation / V_MEME_NOMBRE.py
1 # coding=utf-8
2 # ======================================================================
3 # COPYRIGHT (C) 1991 - 2015  EDF R&D                  WWW.CODE-ASTER.ORG
4 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
5 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
6 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
7 # (AT YOUR OPTION) ANY LATER VERSION.
8 #
9 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
10 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
11 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
12 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
13 #
14 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
15 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
16 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
17 # ======================================================================
18 # person_in_charge: mathieu.courtois at edf.fr
19
20
21 from __future__ import absolute_import
22 try : 
23    from builtins import object
24 except : pass
25
26 class MEME_NOMBRE(object):
27
28     """
29        La regle MEME_NOMBRE verifie que l'on trouve au moins un des mots-cles
30        de la regle parmi les arguments d'un OBJECT.
31
32        Ces arguments sont transmis a la regle pour validation sous la forme
33        d'une liste de noms de mots-cles ou d'un dictionnaire dont
34        les cles sont des noms de mots-cles.
35     """
36
37     def verif(self, args):
38         """
39             La methode verif verifie que l'on trouve au moins un des mos-cles
40             de la liste self.mcs parmi les elements de args
41
42             args peut etre un dictionnaire ou une liste. Les elements de args
43             sont soit les elements de la liste soit les cles du dictionnaire.
44         """
45         #  on compte le nombre de mots cles presents
46         text = ''
47         args = self.liste_to_dico(args)
48         size = -1
49
50         for mc in self.mcs:
51             if mc not in args:
52                 text = "Une cle dans la regle n'existe pas %s" % mc
53                 return text, 0
54
55             val = args[mc].valeur
56             len_val = 0
57             if not isinstance(val, type([])):
58                 len_val = 1
59             else:
60                 len_val = len(val)
61
62             if size == -1:
63                 size = len_val
64             elif size != len_val:
65                 text = "Pas la même longeur"
66                 return text, 0
67         return text, 1