Salome HOME
CCAR: coorection de la prise de focus pour les mots cles simples et la liste des
[tools/eficas.git] / Noyau / N_ASSD.py
1 #@ MODIF N_ASSD Noyau  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
23 """
24 import string
25
26 class ASSD:
27    """
28       Classe de base pour definir des types de structures de donnees ASTER
29       equivalent d un concept ASTER
30    """
31    idracine="SD"
32
33    def __init__(self,etape=None,sd=None,reg='oui'):
34       """
35         reg est un paramètre qui vaut oui ou non :
36           - si oui (défaut) : on enregistre la SD auprès du JDC
37           - si non : on ne l'enregistre pas
38       """
39       self.etape=etape
40       self.sd=sd
41       self.nom=None
42       if etape:
43         self.parent=etape.parent
44       else:
45         self.parent=CONTEXT.get_current_step()
46       if self.parent :
47          self.jdc = self.parent.get_jdc_root()
48       else:
49          self.jdc = None
50
51       if not self.parent:
52         self.id=None
53       elif reg == 'oui' :
54         self.id = self.parent.reg_sd(self)
55       else :
56         self.id = self.parent.o_register(self)
57
58    def __getitem__(self,key):
59       return self.etape[key]
60
61    def is_object(valeur):
62       """
63           Indique si valeur est d'un type conforme à la classe (retourne 1) 
64           ou non conforme (retourne 0)
65       """
66       return 0
67
68    def get_name(self):
69       """
70           Retourne le nom de self, éventuellement en le demandant au JDC
71       """
72       if not self.nom :
73         try:
74           self.nom=self.parent.get_name(self) or self.id
75         except:
76           self.nom=""
77       if string.find(self.nom,'sansnom') != -1 or self.nom == '':
78         self.nom = self.id
79       return self.nom
80
81    def supprime(self):
82       """ 
83           Cassage des boucles de références pour destruction du JDC 
84       """
85       self.etape = None
86       self.sd = None
87       self.jdc = None
88       self.parent = None
89
90    def accept(self,visitor):
91       """
92          Cette methode permet de parcourir l'arborescence des objets
93          en utilisant le pattern VISITEUR
94       """
95       visitor.visitASSD(self)
96
97
98 class assd(ASSD):
99    def is_object(valeur):
100       """
101           Indique si valeur est d'un type conforme à la classe (1) 
102           ou non conforme (0)
103           La classe assd est utilisée pour valider tout objet
104       """
105       return 1
106
107