Salome HOME
Version Aster 6.3.14
[tools/eficas.git] / Validation / V_A_CLASSER.py
1 #@ MODIF V_A_CLASSER 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 import types
23
24 class A_CLASSER:
25    """
26       La règle A_CLASSER vérifie que ...
27
28    """
29    def __init__(self,*args):
30       if len(args) > 2 :
31         print "Erreur à la création de la règle A_CLASSER(",args,")"
32         return
33       self.args=args
34       if type(args[0]) == types.TupleType:
35         self.args0 = args[0]
36       elif type(args[0]) == types.StringType:
37         self.args0 = (args[0],)
38       else :
39         print "Le premier argument de :",args," doit etre un tuple ou une string"
40       if type(args[1]) == types.TupleType:
41         self.args1 = args[1]
42       elif type(args[1]) == types.StringType:
43         self.args1 = (args[1],)
44       else :
45         print "Le deuxième argument de :",args," doit etre un tuple ou une string"
46       # création de la liste des mcs
47       liste = []
48       for arg0 in self.args0:
49         liste.append(arg0)
50       for arg1 in self.args1:
51         liste.append(arg1)
52       self.mcs = liste
53       self.init_couples_permis()
54
55    def init_couples_permis(self):
56       """ Crée la liste des couples permis parmi les self.args, càd pour chaque élément
57           de self.args0 crée tous les couples possibles avec un élément de self.args1"""
58       liste = []
59       for arg0 in self.args0:
60         for arg1 in self.args1:
61           liste.append((arg0,arg1))
62       self.liste_couples = liste
63
64    def verif(self,args):
65       """
66
67           args peut etre un dictionnaire ou une liste. Les éléments de args
68           sont soit les éléments de la liste soit les clés du dictionnaire.
69       """
70       # création de la liste des couples présents dans le fichier de commandes
71       l_couples = []
72       couple = []
73       text = ''
74       test = 1
75       for nom in args:
76         if nom in self.mcs :
77           couple.append(nom)
78           if len(couple) == 2 :
79             l_couples.append(tuple(couple))
80             couple=[]
81             if nom not in self.args1:
82               couple.append(nom)
83       if len(couple) > 0 :
84         l_couples.append(tuple(couple))
85       # l_couples peut etre vide si l'on n'a pas réussi à trouver au moins un
86       # élément de self.mcs
87       if len(l_couples) == 0 :
88         message = "- Il faut qu'au moins un objet de la liste : "+`self.args0`+\
89                   " soit suivi d'au moins un objet de la liste : "+`self.args1`
90         return message,0
91       # A ce stade, on a trouvé des couples : il faut vérifier qu'ils sont
92       # tous licites
93       num = 0
94       for couple in l_couples :
95         num = num+1
96         if len(couple) == 1 :
97           # on a un 'faux' couple
98           if couple[0] not in self.args1:
99             text = text+"- L'objet : "+couple[0]+" doit etre suivi d'un objet de la liste : "+\
100                    `self.args1`+'\n'
101             test = 0
102           else :
103             if num > 1 :
104               # ce n'est pas le seul couple --> licite
105               break
106             else :
107               text = text+"- L'objet : "+couple[0]+" doit etre précédé d'un objet de la liste : "+\
108                    `self.args0`+'\n'
109               test = 0
110         elif couple not in self.liste_couples :
111           text = text+"- L'objet : "+couple[0]+" ne peut etre suivi de : "+couple[1]+'\n'
112           test = 0
113       return text,test
114