]> SALOME platform Git repositories - tools/eficas.git/blob - Validation/V_PRESENT_PRESENT.py
Salome HOME
CCAR: merge du developpement realise dans la branche BR_PN_VAL
[tools/eficas.git] / Validation / V_PRESENT_PRESENT.py
1 #@ MODIF V_PRESENT_PRESENT Validation  DATE 27/03/2002   AUTEUR DURAND C.DURAND 
2 #            CONFIGURATION MANAGEMENT OF EDF VERSION
3 # ======================================================================
4 # COPYRIGHT (C) 1991 - 2002  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 class PRESENT_PRESENT:
23    """
24       La règle vérifie que si le premier mot-clé de self.mcs est present 
25           parmi les elements de args les autres doivent l'etre aussi
26
27       Ces arguments sont transmis à la règle pour validation sous la forme 
28       d'une liste de noms de mots-clés ou d'un dictionnaire dont 
29       les clés sont des noms de mots-clés.
30    """
31    def verif(self,args):
32       """
33           La methode verif effectue la verification specifique à la règle.
34           args peut etre un dictionnaire ou une liste. Les éléments de args
35           sont soit les éléments de la liste soit les clés du dictionnaire.
36       """
37       #  on verifie que si le premier de la liste est present, 
38       #    les autres le sont aussi
39       mc0=self.mcs[0]
40       text=''
41       test = 1
42       args = self.liste_to_dico(args)
43       if args.has_key(mc0):
44         for mc in self.mcs[1:len(self.mcs)]:
45           if not args.has_key(mc):
46             text = text + "- Le mot cle "+`mc0`+" etant present, il faut que : "+mc+" soit present"+'\n'
47             test = 0
48       return text,test
49