Salome HOME
bug
[tools/eficas.git] / Validation / V_PRESENT_PRESENT.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 class PRESENT_PRESENT:
24
25     """
26        La règle vérifie que si le premier mot-clé de self.mcs est present
27            parmi les elements de args les autres doivent l'etre aussi
28
29        Ces arguments sont transmis à la règle pour validation sous la forme
30        d'une liste de noms de mots-clés ou d'un dictionnaire dont
31        les clés sont des noms de mots-clés.
32     """
33
34     def verif(self, args):
35         """
36             La methode verif effectue la verification specifique à la règle.
37             args peut etre un dictionnaire ou une liste. Les éléments de args
38             sont soit les éléments de la liste soit les clés du dictionnaire.
39         """
40         #  on verifie que si le premier de la liste est present,
41         #    les autres le sont aussi
42         mc0 = self.mcs[0]
43         text = ''
44         test = 1
45         args = self.liste_to_dico(args)
46         if args.has_key(mc0):
47             for mc in self.mcs[1:len(self.mcs)]:
48                 if not args.has_key(mc):
49                     text = text + u"- Le mot clé " + `mc0`+ \
50                         u" étant présent, il faut que : " + \
51                         mc + u" soit présent" + '\n'
52                     test = 0
53         return text, test