Solid DevicePrivate object ownership

Jiří Paleček jpalecek at web.de
Thu Nov 5 10:49:36 GMT 2009


Hello,

I've been hunting some memeory leaks in plasma and it seems to me the  
culprit was the solid library. But to understand the matter fully, I need  
clarifications on the following questions:

1) A DevicePrivate for a specific device exists at most once in the  
program, and is always cached in the DeviceManager, is that right?

2) By whom is the m_backendObject of the DevicePrivate owned (and should  
be deleted)?

3)

void Solid::DevicePrivate::setInterface(const DeviceInterface::Type &type,  
DeviceInterface *interface)
{
     ref.ref();
     m_ifaces[type] = interface;
}

Why is the reference count raised every time we add an interface?

4)

void Solid::DevicePrivate::setBackendObject(Ifaces::Device *object)
{
     m_backendObject = object;

     if (m_backendObject) {
         connect(m_backendObject, SIGNAL(destroyed(QObject *)),
                 this, SLOT(_k_destroyed(QObject *)));
     }

     if (!m_ifaces.isEmpty()) {
         foreach (DeviceInterface *iface, m_ifaces) {
             delete iface->d_ptr->backendObject();
             delete iface;
         }

         m_ifaces.clear();

         if (!ref.deref()) deleteLater();
     }
}

And why is it decreased once we reset the backend object?

5)

void Solid::DevicePrivate::setBackendObject(Ifaces::Device *object)
{
...
       foreach (DeviceInterface *iface, m_ifaces) {
             delete iface->d_ptr->backendObject();
             delete iface;
         }

Why do we delete iface->d_ptr->backendObject() here ...

Solid::DevicePrivate::~DevicePrivate()
{
     qDeleteAll(m_ifaces);
}

... and not here?

Regards
     Jiri Palecek

-- 
Using Opera's revolutionary e-mail client: http://www.opera.com/mail/




More information about the kde-core-devel mailing list