Salome HOME
ajout pour accepter les accents sous python 2.3
[tools/eficas.git] / Noyau / N_ASSD.py
1 # -*- coding: utf-8 -*-
2 #@ MODIF N_ASSD Noyau  DATE 27/03/2002   AUTEUR DURAND C.DURAND 
3 #            CONFIGURATION MANAGEMENT OF EDF VERSION
4 # ======================================================================
5 # COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
6 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
7 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
8 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR   
9 # (AT YOUR OPTION) ANY LATER VERSION.                                 
10 #
11 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT 
12 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF          
13 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU    
14 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.                            
15 #
16 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE   
17 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,       
18 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.      
19 #                                                                       
20 #                                                                       
21 # ======================================================================
22 """
23
24 """
25 import string
26
27 class ASSD:
28    """
29       Classe de base pour definir des types de structures de donnees ASTER
30       equivalent d un concept ASTER
31    """
32    idracine="SD"
33
34    def __init__(self,etape=None,sd=None,reg='oui'):
35       """
36         reg est un paramètre qui vaut oui ou non :
37           - si oui (défaut) : on enregistre la SD auprès du JDC
38           - si non : on ne l'enregistre pas
39       """
40       self.etape=etape
41       self.sd=sd
42       self.nom=None
43       if etape:
44         self.parent=etape.parent
45       else:
46         self.parent=CONTEXT.get_current_step()
47       if self.parent :
48          self.jdc = self.parent.get_jdc_root()
49       else:
50          self.jdc = None
51
52       if not self.parent:
53         self.id=None
54       elif reg == 'oui' :
55         self.id = self.parent.reg_sd(self)
56       else :
57         self.id = self.parent.o_register(self)
58
59    def __getitem__(self,key):
60       return self.etape[key]
61
62    def is_object(valeur):
63       """
64           Indique si valeur est d'un type conforme à la classe (retourne 1) 
65           ou non conforme (retourne 0)
66       """
67       return 0
68
69    def get_name(self):
70       """
71           Retourne le nom de self, éventuellement en le demandant au JDC
72       """
73       if not self.nom :
74         try:
75           self.nom=self.parent.get_name(self) or self.id
76         except:
77           self.nom=""
78       if string.find(self.nom,'sansnom') != -1 or self.nom == '':
79         self.nom = self.id
80       return self.nom
81
82    def supprime(self):
83       """ 
84           Cassage des boucles de références pour destruction du JDC 
85       """
86       self.etape = None
87       self.sd = None
88       self.jdc = None
89       self.parent = None
90
91    def accept(self,visitor):
92       """
93          Cette methode permet de parcourir l'arborescence des objets
94          en utilisant le pattern VISITEUR
95       """
96       visitor.visitASSD(self)
97
98
99 class assd(ASSD):
100    def is_object(valeur):
101       """
102           Indique si valeur est d'un type conforme à la classe (1) 
103           ou non conforme (0)
104           La classe assd est utilisée pour valider tout objet
105       """
106       return 1
107
108