[PyQt] Construct QVariant from object of user type
Arve Knudsen
arve.knudsen at gmail.com
Fri Apr 18 12:36:46 BST 2008
On 4/17/08, Arve Knudsen <arve.knudsen at gmail.com> wrote:
> On 4/17/08, Matt Newell <newellm at blur.com> wrote:
> > On Wednesday 16 April 2008 14:18:26 Arve Knudsen wrote:
> > > On Wed, Apr 16, 2008 at 11:33 AM, Phil Thompson
> > >
> > > <phil at riverbankcomputing.co.uk> wrote:
> > > > On Wednesday 16 April 2008, Arve Knudsen wrote:
> > > > > Phil, any comment on this?
> > > > >
> > > > > Thanks,
> > > > > Arve
> > > >
> > > > Unless you can use the ctor that takes a void* I don't see how you can
> > > > expect to extend the functionality of a C++ class from Python.
> > >
> > > How am I supposed to use the QVariant(int typeOrUserType, const void*
> > > copy) constructor from Python? The documentation refers to
> > > sip.voidptr, which I know nothing about, and to use qVariantFromValue
> > > which isn't defined.
> > >
> > > I need to store objects of a custom class in QVariants, with a certain
> > > type code (QVariant::Type). The reason I need to do this is that
> > > QItemEditorFactory is parameterized on QVariant::Type.
> > >
> > > Arve
> >
> >
> >
> > If you look at qmetatype.h, you'll see that it should be possible to create a
> > mechanism to register custom python classes as QVariant types. You just need
> > to implement Constructor/Destructor methods that call Py_INCREF/Py_DECREF.
> > Then for each custom python type call QMetaType::registerType(...). This
> > would need to be implemented in c++ with a python interface.
> >
> > You could then write a custom QVariant constructor that detects if the python
> > object's type is registered, and automatically call the QVariant(int
> > type,void*) ctor, or throws an exception for non-registered types.
>
>
> So I would *have to* do this in C++? Ugh.
Phil: Can you confirm that I have to do this via C++?
Thanks,
Arve
More information about the PyQt
mailing list