[Kde-bindings] problem with sip api 2 for QString

Wolfgang Rohdewald wolfgang at rohdewald.de
Fri Dec 28 14:03:17 UTC 2012


Hi,

could somebody please have a look at bug 253123?
https://bugs.kde.org/show_bug.cgi?id=253123

without this being fixed I will never be able to port the kde game kajongg to
the new API. I want to change to the new API before trying the port to python3.

re-tested again today:

the full test script is:

#!/usr/bin/env python3
import sip
sip.setapi('QString', 2)
from PyKDE4.kdeui import KConfigSkeleton
a = KConfigSkeleton()
name = 'tilesetName'
value = 'I am a value'
s = a.addItemString(name, value)
print('s.value():', s.value())  # --------- this prints random garbage, accessing a freed object

doing something similar with addItemInt works.

it seems the code generated by sip frees the string value object when it should not (by calling
sipReleaseType)

I know nothing about sip, so I have no idea how to fix this. That bug was always there
since I reported it in oct 2010, now I get it with pykde4-4.9.4 with both python 2.7.3 and
python 3.2 - so it really is version independent.

valgrind says 
==6835== Invalid read of size 8
==6835==    at 0x99C74CB: QString::toUcs4() const (in /usr/lib/x86_64-linux-gnu/libQtCore.so.4.8.3)
==6835==    by 0xF1B698F: ??? (in /usr/lib/python3/dist-packages/PyQt4/QtCore.cpython-32mu.so)
==6835==    by 0x79CFB38: sip_api_convert_from_type (in /usr/lib/python3/dist-packages/sip.cpython-32mu.so)
==6835==    by 0x1061B01B: meth_KCoreConfigSkeleton_ItemString_value (sipkdecorepart6.cpp:12455)
==6835==  Address 0x112f4800 is 0 bytes inside a block of size 8 free'd
==6835==    at 0x4C2A44B: operator delete(void*) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==6835==    by 0xF0FB872: ??? (in /usr/lib/python3/dist-packages/PyQt4/QtCore.cpython-32mu.so)
==6835==    by 0x106361F4: meth_KCoreConfigSkeleton_addItemString (sipkdecorepart6.cpp:13726)

extracts from sipkdecorepart6.cpp (generated on kubuntu with apt-get --compile source python-kde4):

extern "C" {static PyObject *meth_KCoreConfigSkeleton_ItemString_value(PyObject *, PyObject *);}
static PyObject *meth_KCoreConfigSkeleton_ItemString_value(PyObject *sipSelf, PyObject *sipArgs)
{
    PyObject *sipParseErr = NULL;

    {
        KCoreConfigSkeleton::ItemString *sipCpp;

        if (sipParseArgs(&sipParseErr, sipArgs, "B", &sipSelf, sipType_KCoreConfigSkeleton_ItemString, &sipCpp))
        {
            QString *sipRes;

            Py_BEGIN_ALLOW_THREADS
            sipRes = &sipCpp->value();   ----------------------- this is line 12455
            Py_END_ALLOW_THREADS

            return sipConvertFromType(sipRes,sipType_QString,NULL);
        }
    }

extern "C" {static PyObject *meth_KCoreConfigSkeleton_addItemString(PyObject *, PyObject *);}
static PyObject *meth_KCoreConfigSkeleton_addItemString(PyObject *sipSelf, PyObject *sipArgs)
{
    PyObject *sipParseErr = NULL;

    {
        const QString * a0;
        int a0State = 0;
        QString * a1;
        int a1State = 0;
        const QString& a2def = QLatin1String("");
        const QString * a2 = &a2def;
        int a2State = 0;
        const QString& a3def = QString();
        const QString * a3 = &a3def;
        int a3State = 0;
        KCoreConfigSkeleton *sipCpp;

        if (sipParseArgs(&sipParseErr, sipArgs, "BJ1J1|J1J1", &sipSelf, sipType_KCoreConfigSkeleton, &sipCpp, sipType_QString,&a0, &a0State, sipType_QString,&a1, &a1State, sipType_QString,&a2, &a2State, sipType_QString,&a3, &a3State))
        {
            KCoreConfigSkeleton::ItemString *sipRes;

            Py_BEGIN_ALLOW_THREADS
            sipRes = sipCpp->addItemString(*a0,*a1,*a2,*a3);
            Py_END_ALLOW_THREADS
            sipReleaseType(const_cast<QString *>(a0),sipType_QString,a0State);
            sipReleaseType(a1,sipType_QString,a1State);  ----------------------------------- this is line 13726
            sipReleaseType(const_cast<QString *>(a2),sipType_QString,a2State);
            sipReleaseType(const_cast<QString *>(a3),sipType_QString,a3State);

            return sipConvertFromType(sipRes,sipType_KCoreConfigSkeleton_ItemString,NULL);
        }


-- 
Wolfgang


More information about the Kde-bindings mailing list