]> SALOME platform Git repositories - tools/eficas.git/blob - Noyau/N_ASSD.py
Salome HOME
*** empty log message ***
[tools/eficas.git] / Noyau / N_ASSD.py
1 #@ MODIF N_ASSD Noyau  DATE 14/12/2009   AUTEUR COURTOIS M.COURTOIS 
2 # -*- coding: iso-8859-1 -*-
3 # RESPONSABLE COURTOIS M.COURTOIS
4 #            CONFIGURATION MANAGEMENT OF EDF VERSION
5 # ======================================================================
6 # COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
7 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
8 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
9 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR   
10 # (AT YOUR OPTION) ANY LATER VERSION.                                 
11 #
12 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT 
13 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF          
14 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU    
15 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.                            
16 #
17 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE   
18 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,       
19 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.      
20 #                                                                       
21 #                                                                       
22 # ======================================================================
23
24
25 """
26
27 """
28
29 class ASSD(object):
30    """
31       Classe de base pour definir des types de structures de donnees ASTER
32       equivalent d un concept ASTER
33    """
34    idracine="SD"
35
36    def __init__(self,etape=None,sd=None,reg='oui'):
37       """
38         reg est un paramètre qui vaut oui ou non :
39           - si oui (défaut) : on enregistre la SD auprès du JDC
40           - si non : on ne l'enregistre pas
41       """
42       self.etape=etape
43       self.sd=sd
44       self.nom=None
45       if etape:
46         self.parent=etape.parent
47       else:
48         self.parent=CONTEXT.get_current_step()
49       if self.parent :
50          self.jdc = self.parent.get_jdc_root()
51       else:
52          self.jdc = None
53
54       if not self.parent:
55         self.id=None
56       elif reg == 'oui' :
57         self.id = self.parent.reg_sd(self)
58       else :
59         self.id = self.parent.o_register(self)
60       # permet de savoir si le concept a été calculé (1) ou non (0)
61       self.executed = 0
62       
63    def __getitem__(self,key):
64       return self.etape[key]
65    
66    def set_name(self, nom):
67       """Positionne le nom de self (et appelle sd_init)
68       """
69       self.nom = nom
70       # initialise la partie "sd" (pas pour entier, reel, formule)
71       sup = super(ASSD, self)
72       if hasattr(sup, 'nomj'):   # == AsBase
73          sup.__init__(nomj=nom)
74       self.reparent_sd()
75    
76    def reparent_sd(self):
77       """Repositionne le parent des attributs de la SD associée.
78       """
79       sup = super(ASSD, self)
80       if hasattr(sup, 'nomj'):   # == AsBase
81          sup.reparent(None, None)
82
83    def get_name(self):
84       """
85           Retourne le nom de self, éventuellement en le demandant au JDC
86       """
87       if not self.nom :
88          try:
89             self.nom=self.parent.get_name(self) or self.id
90          except:
91             self.nom=""
92       if self.nom.find('sansnom') != -1 or self.nom == '':
93          self.nom = self.id
94       return self.nom
95
96    def supprime(self):
97       """ 
98           Cassage des boucles de références pour destruction du JDC 
99       """
100       self.etape = None
101       self.sd = None
102       self.jdc = None
103       self.parent = None
104
105    def accept(self,visitor):
106       """
107          Cette methode permet de parcourir l'arborescence des objets
108          en utilisant le pattern VISITEUR
109       """
110       visitor.visitASSD(self)
111
112    def __getstate__(self):
113       """
114           Cette methode permet de pickler les objets ASSD
115           Ceci est possible car on coupe les liens avec les objets
116           parent, etape et jdc qui conduiraient à pickler de nombreux 
117           objets inutiles ou non picklables.
118       """
119       d=self.__dict__.copy()
120       for key in ('parent','etape','jdc'):
121           if d.has_key(key):del d[key]
122       for key in d.keys():
123           if key[0]=='_':del d[key]
124       return d
125
126
127    def accessible(self):
128       """Dit si on peut acceder aux "valeurs" (jeveux) de l'ASSD.
129       """
130       if CONTEXT.debug: print '| accessible ?', self.nom
131       is_accessible = CONTEXT.get_current_step().sd_accessible()
132       if CONTEXT.debug: print '  `- is_accessible =', repr(is_accessible)
133       return is_accessible
134
135
136    def par_lot(self):
137       """Conserver uniquement pour la compatibilite avec le catalogue v9 dans eficas.
138       """
139       #XXX eficas
140       if not hasattr(self, 'jdc') or self.jdc == None:
141          val = None
142       else:
143          val = self.jdc.par_lot
144       return val == 'OUI'
145
146
147 class assd(ASSD):
148    def __convert__(cls,valeur):
149       return valeur
150    __convert__=classmethod(__convert__)