Salome HOME
F.R: -modifs procédure d'installation et suppression de code_aster.gif
[tools/eficas.git] / Noyau / N_ASSD.py
1 """
2
3 """
4 import string
5
6 class ASSD:
7    """
8       Classe de base pour definir des types de structures de donnees ASTER
9       equivalent d un concept ASTER
10    """
11    idracine="SD"
12
13    def __init__(self,etape=None,sd=None,reg='oui'):
14       """
15         reg est un paramètre qui vaut oui ou non :
16           - si oui (défaut) : on enregistre la SD auprès du JDC
17           - si non : on ne l'enregistre pas
18       """
19       self.etape=etape
20       self.sd=sd
21       self.nom=None
22       if etape:
23         self.parent=etape.parent
24       else:
25         self.parent=CONTEXT.get_current_step()
26       if self.parent :
27          self.jdc = self.parent.get_jdc_root()
28       else:
29          self.jdc = None
30
31       if not self.parent:
32         self.id=None
33       elif reg == 'oui' :
34         self.id = self.parent.reg_sd(self)
35       else :
36         self.id = self.parent.o_register(self)
37
38    def __getitem__(self,key):
39       return self.etape[key]
40
41    def is_object(valeur):
42       """
43           Indique si valeur est d'un type conforme à la classe (retourne 1) 
44           ou non conforme (retourne 0)
45       """
46       return 0
47
48    def get_name(self):
49       """
50           Retourne le nom de self, éventuellement en le demandant au JDC
51       """
52       if not self.nom :
53         try:
54           self.nom=self.parent.get_name(self) or self.id
55         except:
56           self.nom=""
57       if string.find(self.nom,'sansnom') != -1 or self.nom == '':
58         self.nom = self.id
59       return self.nom
60
61    def supprime(self):
62       """ 
63           Cassage des boucles de références pour destruction du JDC 
64       """
65       self.etape = None
66       self.sd = None
67       self.jdc = None
68       self.parent = None
69
70    def accept(self,visitor):
71       """
72          Cette methode permet de parcourir l'arborescence des objets
73          en utilisant le pattern VISITEUR
74       """
75       visitor.visitASSD(self)
76
77
78 class assd(ASSD):
79    def is_object(valeur):
80       """
81           Indique si valeur est d'un type conforme à la classe (1) 
82           ou non conforme (0)
83           La classe assd est utilisée pour valider tout objet
84       """
85       return 1
86
87