Salome HOME
CCAR: modification de la procedure d'installation : install.py et de
[tools/eficas.git] / Validation / V_A_CLASSER.py
1
2 import types
3
4 class A_CLASSER:
5    """
6       La règle A_CLASSER vérifie que ...
7
8    """
9    def __init__(self,*args):
10       if len(args) > 2 :
11         print "Erreur à la création de la règle A_CLASSER(",args,")"
12         return
13       self.args=args
14       if type(args[0]) == types.TupleType:
15         self.args0 = args[0]
16       elif type(args[0]) == types.StringType:
17         self.args0 = (args[0],)
18       else :
19         print "Le premier argument de :",args," doit être un tuple ou une string"
20       if type(args[1]) == types.TupleType:
21         self.args1 = args[1]
22       elif type(args[1]) == types.StringType:
23         self.args1 = (args[1],)
24       else :
25         print "Le deuxième argument de :",args," doit être un tuple ou une string"
26       # création de la liste des mcs
27       liste = []
28       for arg0 in self.args0:
29         liste.append(arg0)
30       for arg1 in self.args1:
31         liste.append(arg1)
32       self.mcs = liste
33       self.init_couples_permis()
34
35    def init_couples_permis(self):
36       """ Crée la liste des couples permis parmi les self.args, càd pour chaque élément
37           de self.args0 crée tous les couples possibles avec un élément de self.args1"""
38       liste = []
39       for arg0 in self.args0:
40         for arg1 in self.args1:
41           liste.append((arg0,arg1))
42       self.liste_couples = liste
43
44    def verif(self,args):
45       """
46
47           args peut etre un dictionnaire ou une liste. Les éléments de args
48           sont soit les éléments de la liste soit les clés du dictionnaire.
49       """
50       # création de la liste des couples présents dans le fichier de commandes
51       l_couples = []
52       couple = []
53       text = ''
54       test = 1
55       for nom in args:
56         if nom in self.mcs :
57           couple.append(nom)
58           if len(couple) == 2 :
59             l_couples.append(tuple(couple))
60             couple=[]
61             if nom not in self.args1:
62               couple.append(nom)
63       if len(couple) > 0 :
64         l_couples.append(tuple(couple))
65       # l_couples peut être vide si l'on n'a pas réussi à trouver au moins un
66       # élément de self.mcs
67       if len(l_couples) == 0 :
68         message = "- Il faut qu'au moins un objet de la liste : "+`self.args0`+\
69                   " soit suivi d'au moins un objet de la liste : "+`self.args1`
70         return message,0
71       # A ce stade, on a trouvé des couples : il faut vérifier qu'ils sont
72       # tous licites
73       num = 0
74       for couple in l_couples :
75         num = num+1
76         if len(couple) == 1 :
77           # on a un 'faux' couple
78           if couple[0] not in self.args1:
79             text = text+"- L'objet : "+couple[0]+" doit être suivi d'un objet de la liste : "+\
80                    `self.args1`+'\n'
81             test = 0
82           else :
83             if num > 1 :
84               # ce n'est pas le seul couple --> licite
85               break
86             else :
87               text = text+"- L'objet : "+couple[0]+" doit être précédé d'un objet de la liste : "+\
88                    `self.args0`+'\n'
89               test = 0
90         elif couple not in self.liste_couples :
91           text = text+"- L'objet : "+couple[0]+" ne peut être suivi de : "+couple[1]+'\n'
92           test = 0
93       return text,test
94