Salome HOME
sauve du 20/12
[tools/eficas.git] / Noyau / N_ASSD_NonAster.py
1 # -*- coding: iso-8859-1 -*-
2 # Copyright (C) 2007-2013   EDF R&D
3 #
4 # This library is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU Lesser General Public
6 # License as published by the Free Software Foundation; either
7 # version 2.1 of the License.
8 #
9 # This library is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12 # Lesser General Public License for more details.
13 #
14 # You should have received a copy of the GNU Lesser General Public
15 # License along with this library; if not, write to the Free Software
16 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
17 #
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
19
20 """
21
22 """
23
24 class ASSD(object):
25    """
26       Classe de base pour definir des types de structures de donnees ASTER
27       equivalent d un concept ASTER
28    """
29    idracine="SD"
30
31    def __init__(self,etape=None,sd=None,reg='oui'):
32       """
33         reg est un paramètre qui vaut oui ou non :
34           - si oui (défaut) : on enregistre la SD auprès du JDC
35           - si non : on ne l'enregistre pas
36       """
37       self.etape=etape
38       self.sd=sd
39       self.nom=None
40       if etape:
41         self.parent=etape.parent
42       else:
43         self.parent=CONTEXT.get_current_step()
44       if self.parent :
45          self.jdc = self.parent.get_jdc_root()
46       else:
47          self.jdc = None
48
49       if not self.parent:
50         self.id=None
51       elif reg == 'oui' :
52         self.id = self.parent.reg_sd(self)
53       else :
54         self.id = self.parent.o_register(self)
55       # permet de savoir si le concept a été calculé (1) ou non (0)
56       self.executed = 0
57       # initialise la partie "sd"
58       super(ASSD, self).__init__(nomj='?&?&?&?&')
59       
60    def __getitem__(self,key):
61       return self.etape[key]
62
63    def set_name(self, nom):
64       """Positionne le nom de self (et appelle sd_init)
65       """
66       self.nom = nom
67       # test car FORMULE n'a pas de SD associée
68       meth = getattr(super(ASSD, self), 'set_name', None)
69       if meth:
70          meth(nom)
71    
72    def reparent_sd(self):
73       """Repositionne le parent des attributs de la SD associée.
74       """
75       # test car FORMULE n'a pas de SD associée
76       meth = getattr(super(ASSD, self), 'reparent', None)
77       if meth:
78          meth(None, None)
79    
80    def get_name(self):
81       """
82           Retourne le nom de self, éventuellement en le demandant au JDC
83       """
84       if not self.nom :
85          try:
86             self.nom=self.parent.get_name(self) or self.id
87          except:
88             self.nom=""
89       if self.nom.find('sansnom') != -1 or self.nom == '':
90          self.nom = self.id
91       return self.nom
92
93    def supprime(self):
94       """ 
95           Cassage des boucles de références pour destruction du JDC 
96       """
97       self.etape = None
98       self.sd = None
99       self.jdc = None
100       self.parent = None
101
102    def accept(self,visitor):
103       """
104          Cette methode permet de parcourir l'arborescence des objets
105          en utilisant le pattern VISITEUR
106       """
107       visitor.visitASSD(self)
108
109    def __getstate__(self):
110       """
111           Cette methode permet de pickler les objets ASSD
112           Ceci est possible car on coupe les liens avec les objets
113           parent, etape et jdc qui conduiraient à pickler de nombreux 
114           objets inutiles ou non picklables.
115       """
116       d=self.__dict__.copy()
117       for key in ('parent','etape','jdc'):
118           if d.has_key(key):del d[key]
119       for key in d.keys():
120           if key[0]=='_':del d[key]
121       return d
122
123    def par_lot(self):
124       """
125            Retourne True si l'ASSD est créée en mode PAR_LOT='OUI'.
126       """
127       if not hasattr(self, 'jdc') or self.jdc == None:
128          val = None
129       else:
130          val = self.jdc.par_lot
131       return val == 'OUI'
132
133 class assd(ASSD):
134    def __convert__(cls,valeur):
135       return valeur
136    __convert__=classmethod(__convert__)