source: mauRepo/CedaMolesModel/trunk/ceda_moles_model/ea_model/iso_19115_2006_metadata_corrigendum/extent_information/ex_spatialtemporalextent.py @ 8457

Subversion URL: http://proj.badc.rl.ac.uk/svn/ndg/mauRepo/CedaMolesModel/trunk/ceda_moles_model/ea_model/iso_19115_2006_metadata_corrigendum/extent_information/ex_spatialtemporalextent.py@8457
Revision 8457, 3.0 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 ea_model.iso_19115_2006_metadata_corrigendum.extent_information.ex_temporalextent import  EX_TemporalExtent
22from ascore.utils import has_value, collectionProofHash
23
24'''
25Created on 10-Jul-2012 14:15:02
26
27@author: mnagni
28'''
29
30class EX_SpatialTemporalExtent(EX_TemporalExtent):
31        '''
32                Represents a data entity defined in a UML diagram and supposed to
33                be persisted in a relational database.
34 
35                This class has been genererated automatically using the Apache Velocity project.
36        '''
37        '''
38                Please note that any access to the inner attributes should be done using
39                the given get/set methods and NOT accessing them directly.
40        '''
41        def __init__(self):
42                self._ex_temporalextent = EX_TemporalExtent()   
43
44                self._spatialExtent_ex_geographicdescription = []
45                self._spatialExtent_ex_geographicboundingbox = []
46                self._spatialExtent_ex_boundingpolygon = []
47                self._spatialExtent = []
48                self.extent = None
49                super(EX_SpatialTemporalExtent, self).__init__()
50        @property
51        def spatialExtent(self):       
52                try:
53                        ret = []
54                        ret.extend(self._spatialExtent_ex_geographicdescription)
55                        ret.extend(self._spatialExtent_ex_geographicboundingbox)
56                        ret.extend(self._spatialExtent_ex_boundingpolygon)
57                        if not hasattr(self, '_spatialExtent'):
58                                self._spatialExtent = []
59                        if self._spatialExtent is not None:
60                                ret.extend(self._spatialExtent)
61                        del self._spatialExtent[:]
62                        self._spatialExtent.extend(set(ret))
63                except Exception as e:
64                        pass
65                return self._spatialExtent
66
67        @property
68        def extent(self):       
69                return self._ex_temporalextent.extent
70
71        @extent.setter
72        def extent(self, value):       
73                        self._ex_temporalextent.extent = value
74
75        def synchronize(self):
76                int_spatialExtent = self.spatialExtent 
77                del self._spatialExtent_ex_geographicdescription[:]
78                del self._spatialExtent_ex_geographicboundingbox[:]
79                del self._spatialExtent_ex_boundingpolygon[:]
80                for item in int_spatialExtent: 
81                        valueClass = "%s.%s" % (type(item).__module__,type(item).__name__)
82                        if valueClass == "ea_model.iso_19115_2006_metadata_corrigendum.extent_information.ex_geographicdescription.EX_GeographicDescription":
83                                self._spatialExtent_ex_geographicdescription.append(item)
84                                continue
85                        if valueClass == "ea_model.iso_19115_2006_metadata_corrigendum.extent_information.ex_geographicboundingbox.EX_GeographicBoundingBox":
86                                self._spatialExtent_ex_geographicboundingbox.append(item)
87                                continue
88                        if valueClass == "ea_model.iso_19115_2006_metadata_corrigendum.extent_information.ex_boundingpolygon.EX_BoundingPolygon":
89                                self._spatialExtent_ex_boundingpolygon.append(item)
90                                continue
91                pass
92
93        def __key(self):
94                return (self.spatialExtent, self.extent)
95
96        def __eq__(self, y):
97                if type(self) != type(y):
98                        return False
99                '''
100                Cannot compare classes which do not define a "__key" attribute
101                '''
102                if hasattr(self, '_%s__key' % (type(self).__name__)) and hasattr(y, '_%s__key' % (type(y).__name__)):
103                        return self.__key() == y.__key()
104                return id(self) == id(y)
105
106        def __hash__(self):
107                return collectionProofHash(self.__key())
Note: See TracBrowser for help on using the repository browser.