diff options
| author | Johan Dahlin <jdahlin@async.com.br> | 2007-08-27 15:59:00 +0000 |
|---|---|---|
| committer | Johan Dahlin <johan@src.gnome.org> | 2007-08-27 15:59:00 +0000 |
| commit | f66505b9e43226d731fefdfd37325f411f7e0de1 (patch) | |
| tree | daccdf37ef74de09a53323503f8100fa960ec285 /gobject | |
| parent | 078439f05b12ed4756e87f0e8c1c6ff1e93da880 (diff) | |
| download | pygobject-f66505b9e43226d731fefdfd37325f411f7e0de1.tar.gz pygobject-f66505b9e43226d731fefdfd37325f411f7e0de1.tar.xz pygobject-f66505b9e43226d731fefdfd37325f411f7e0de1.zip | |
Refactor a bit to make sure that it is possible to use in subclasses,
2007-08-27 Johan Dahlin <jdahlin@async.com.br>
* gobject/__init__.py (GObjectMeta._install_properties):
Refactor a bit to make sure that it is possible to use in subclasses,
fixes #470718 (Marco Giusti)
svn path=/trunk/; revision=699
Diffstat (limited to 'gobject')
| -rw-r--r-- | gobject/__init__.py | 15 |
1 files changed, 7 insertions, 8 deletions
diff --git a/gobject/__init__.py b/gobject/__init__.py index d251d31..c1404f9 100644 --- a/gobject/__init__.py +++ b/gobject/__init__.py @@ -42,27 +42,26 @@ class GObjectMeta(type): def _install_properties(cls): gproperties = getattr(cls, '__gproperties__', {}) - props = {} + + props = [] for name, prop in cls.__dict__.items(): if isinstance(prop, property): # not same as the built-in if name in gproperties: raise ValueError prop.name = name - props[name] = prop.get_pspec_args() + gproperties[name] = prop.get_pspec_args() + props.append(prop) if not props: return - if not gproperties: - cls.__gproperties__ = props - else: - gproperties.update(props) + cls.__gproperties__ = gproperties if (hasattr(cls, 'do_get_property') or hasattr(cls, 'do_set_property')): for prop in props: - if (prop.getter != prop.default_getter or - prop.setter != prop.default_setter): + if (prop.getter != prop._default_getter or + prop.setter != prop._default_setter): raise TypeError( "GObject subclass %r defines do_get/set_property" " and it also uses a property which a custom setter" |
