added a proxy to the deprecated Feature.properties interface in the python bindings
This commit is contained in:
parent
c47cd93f93
commit
e8a4929a5a
1 changed files with 21 additions and 4 deletions
|
@ -234,13 +234,30 @@ class _Datasource(Datasource,_injector):
|
||||||
query.add_property_name(fld)
|
query.add_property_name(fld)
|
||||||
return self.features(query).features
|
return self.features(query).features
|
||||||
|
|
||||||
|
class _DeprecatedFeatureProperties(object):
|
||||||
|
def __init__(self, feature):
|
||||||
|
self._feature = feature
|
||||||
|
|
||||||
|
def __getitem__(self, name):
|
||||||
|
from warnings import warn
|
||||||
|
warn("indexing feature.properties is deprecated, index the "
|
||||||
|
"feature object itself for the same effect", DeprecationWarning, 2)
|
||||||
|
return self._feature[name]
|
||||||
|
|
||||||
|
def __iter__(self):
|
||||||
|
from warnings import warn
|
||||||
|
warn("iterating feature.properties is deprecated, iterate the "
|
||||||
|
"feature object itself for the same effect", DeprecationWarning, 2)
|
||||||
|
return iter(self._feature)
|
||||||
|
|
||||||
class _Feature(Feature,_injector):
|
class _Feature(Feature,_injector):
|
||||||
|
@property
|
||||||
|
def properties(self):
|
||||||
|
return _DeprecatedFeatureProperties(self)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def attributes(self):
|
def attributes(self):
|
||||||
attr = {}
|
return dict(self)
|
||||||
for prop in self.properties:
|
|
||||||
attr[prop[0]] = prop[1]
|
|
||||||
return attr
|
|
||||||
|
|
||||||
class _Symbolizer(Symbolizer,_injector):
|
class _Symbolizer(Symbolizer,_injector):
|
||||||
def symbol(self):
|
def symbol(self):
|
||||||
|
|
Loading…
Reference in a new issue