source: mauRepo/CedaMolesModel/trunk/ceda_moles_model/ea_model/iso_19123_2005_coverages/coverages/coverage_core/cv_domainobject.py @ 8457

Subversion URL: http://proj.badc.rl.ac.uk/svn/ndg/mauRepo/CedaMolesModel/trunk/ceda_moles_model/ea_model/iso_19123_2005_coverages/coverages/coverage_core/cv_domainobject.py@8457
Revision 8457, 4.5 KB checked in by mnagni, 7 years ago (diff)

Corrected an error in the generation of the classes "synchronize" method.

  • Property svn:mime-type set to text/plain
Line 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21from ascore.utils import has_value, collectionProofHash
22
23'''
24Created on 10-Jul-2012 14:15:10
25
26@author: mnagni
27'''
28
29class CV_DomainObject(object):
30        '''
31                Represents a data entity defined in a UML diagram and supposed to
32                be persisted in a relational database.
33 
34                This class has been genererated automatically using the Apache Velocity project.
35        '''
36        '''
37                Please note that any access to the inner attributes should be done using
38                the given get/set methods and NOT accessing them directly.
39        '''
40        def __init__(self):
41
42                self._collection_cv_discretecoverage = None
43                self._collection_cv_continuouscoverage = None
44                self._collection = None
45                self._spatialElement_gm_aggregate = []
46                self._spatialElement_gm_primitive = []
47                self._spatialElement_gm_complex = []
48                self._spatialElement = []
49                self._temporalElement_tm_instant = []
50                self._temporalElement_tm_period = []
51                self._temporalElement = []
52                super(CV_DomainObject, self).__init__()
53        @property
54        def collection(self):   
55                if(has_value(self._collection_cv_discretecoverage)):
56                        return self._collection_cv_discretecoverage
57                if(has_value(self._collection_cv_continuouscoverage)):
58                        return self._collection_cv_continuouscoverage
59                return  None
60
61        @collection.setter
62        def collection(self, value):   
63                valueClass = "%s.%s" % (type(value).__module__,type(value).__name__)
64                if valueClass == "ea_model.iso_19123_2005_coverages.coverages.discrete_coverages.cv_discretecoverage.CV_DiscreteCoverage":
65                        self._collection_cv_discretecoverage = value
66                        self._collection_cv_continuouscoverage = None
67                if valueClass == "ea_model.iso_19123_2005_coverages.coverages.coverage_core.cv_continuouscoverage.CV_ContinuousCoverage":
68                        self._collection_cv_continuouscoverage = value
69                        self._collection_cv_discretecoverage = None
70        @property
71        def spatialElement(self):       
72                try:
73                        ret = []
74                        ret.extend(self._spatialElement_gm_aggregate)
75                        ret.extend(self._spatialElement_gm_primitive)
76                        ret.extend(self._spatialElement_gm_complex)
77                        if not hasattr(self, '_spatialElement'):
78                                self._spatialElement = []
79                        if self._spatialElement is not None:
80                                ret.extend(self._spatialElement)
81                        del self._spatialElement[:]
82                        self._spatialElement.extend(set(ret))
83                except Exception as e:
84                        pass
85                return self._spatialElement
86
87        @property
88        def temporalElement(self):     
89                try:
90                        ret = []
91                        ret.extend(self._temporalElement_tm_instant)
92                        ret.extend(self._temporalElement_tm_period)
93                        if not hasattr(self, '_temporalElement'):
94                                self._temporalElement = []
95                        if self._temporalElement is not None:
96                                ret.extend(self._temporalElement)
97                        del self._temporalElement[:]
98                        self._temporalElement.extend(set(ret))
99                except Exception as e:
100                        pass
101                return self._temporalElement
102
103
104        def synchronize(self):
105                int_spatialElement = self.spatialElement       
106                del self._spatialElement_gm_aggregate[:]
107                del self._spatialElement_gm_primitive[:]
108                del self._spatialElement_gm_complex[:]
109                int_temporalElement = self.temporalElement     
110                del self._temporalElement_tm_instant[:]
111                del self._temporalElement_tm_period[:]
112                for item in int_spatialElement:
113                        valueClass = "%s.%s" % (type(item).__module__,type(item).__name__)
114                        if valueClass == "ea_model.iso_19107_2003_spatial_schema.geometry.geometric_aggregates.gm_aggregate.GM_Aggregate":
115                                self._spatialElement_gm_aggregate.append(item)
116                                continue
117                        if valueClass == "ea_model.iso_19107_2003_spatial_schema.geometry.geometric_primitive.gm_primitive.GM_Primitive":
118                                self._spatialElement_gm_primitive.append(item)
119                                continue
120                        if valueClass == "ea_model.iso_19107_2003_spatial_schema.geometry.geometric_complex.gm_complex.GM_Complex":
121                                self._spatialElement_gm_complex.append(item)
122                                continue
123                for item in int_temporalElement:       
124                        valueClass = "%s.%s" % (type(item).__module__,type(item).__name__)
125                        if valueClass == "ea_model.iso_19108_2006_temporal_schema.temporal_objects.tm_instant.TM_Instant":
126                                self._temporalElement_tm_instant.append(item)
127                                continue
128                        if valueClass == "ea_model.iso_19108_2006_temporal_schema.temporal_objects.tm_period.TM_Period":
129                                self._temporalElement_tm_period.append(item)
130                                continue
131                pass
132
133        def __key(self):
134                return (self.collection, self.spatialElement, self.temporalElement)
135
136        def __eq__(self, y):
137                if type(self) != type(y):
138                        return False
139                '''
140                Cannot compare classes which do not define a "__key" attribute
141                '''
142                if hasattr(self, '_%s__key' % (type(self).__name__)) and hasattr(y, '_%s__key' % (type(y).__name__)):
143                        return self.__key() == y.__key()
144                return id(self) == id(y)
145
146        def __hash__(self):
147                return collectionProofHash(self.__key())
Note: See TracBrowser for help on using the repository browser.