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.
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.
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.
22 # ======================================================================
31 Classe de base pour definir des types de structures de donnees ASTER
32 equivalent d un concept ASTER
36 def __init__(self,etape=None,sd=None,reg='oui'):
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
46 self.parent=etape.parent
48 self.parent=CONTEXT.get_current_step()
50 self.jdc = self.parent.get_jdc_root()
57 self.id = self.parent.reg_sd(self)
59 self.id = self.parent.o_register(self)
60 # permet de savoir si le concept a été calculé (1) ou non (0)
63 def __getitem__(self,key):
64 return self.etape[key]
66 def set_name(self, nom):
67 """Positionne le nom de self (et appelle sd_init)
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)
76 def reparent_sd(self):
77 """Repositionne le parent des attributs de la SD associée.
79 sup = super(ASSD, self)
80 if hasattr(sup, 'nomj'): # == AsBase
81 sup.reparent(None, None)
85 Retourne le nom de self, éventuellement en le demandant au JDC
89 self.nom=self.parent.get_name(self) or self.id
92 if self.nom.find('sansnom') != -1 or self.nom == '':
98 Cassage des boucles de références pour destruction du JDC
105 def accept(self,visitor):
107 Cette methode permet de parcourir l'arborescence des objets
108 en utilisant le pattern VISITEUR
110 visitor.visitASSD(self)
112 def __getstate__(self):
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.
119 d=self.__dict__.copy()
120 for key in ('parent','etape','jdc'):
121 if d.has_key(key):del d[key]
123 if key[0]=='_':del d[key]
127 def accessible(self):
128 """Dit si on peut acceder aux "valeurs" (jeveux) de l'ASSD.
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)
137 """Conserver uniquement pour la compatibilite avec le catalogue v9 dans eficas.
140 if not hasattr(self, 'jdc') or self.jdc == None:
143 val = self.jdc.par_lot
148 def __convert__(cls,valeur):
150 __convert__=classmethod(__convert__)