[Grok-dev] Re: Martian and ExtensionClasses.

Martijn Faassen faassen at startifact.com
Sun Apr 27 12:51:00 EDT 2008


Lennart Regebro wrote:
> When writing the changelog for the EventClass support I realized maybe
> this was useful for metclasses as well.
> So I asked on #python and Thomas Wouters in his useful style of
> helpful rudeness recommended that we don't do type(obj) at all, but
> that we do
> isinstance(obj, ...). So I tried that:
> 
>     def grokkers(self, name, obj):
>         obj_type = type(obj)
>         if isinstance(obj, (type, types.ClassType)):
>             return self._multi_class_grokker.grokkers(name, obj)
>         elif isinstance(obj, types.ModuleType):
>             return self._multi_global_grokker.grokkers(name, obj)
>         else:
>             return self._multi_instance_grokker.grokkers(name, obj)
> 
> This works with ExtensionClasses, and it is supposed to work with
> metaclasses as well.
> 
> So question to Martijn: Is there any reason you used type(obj) instead
> of isinstance(obj, ...) ? It seems like with this change we don't need
> to extend the list of classes.

No particular reason. I hadn't thought of using isinstance on classes, 
but classes are instances of meta-classes so I imagine that does work.

What's obj_type still doing there, by the way? You don't seem to use it.

Regards,

Martijn



More information about the Grok-dev mailing list