qtmobility/plugins/contacts/qtcontacts-tracker/trackerchangelistener.cpp
changeset 14 6fbed849b4f4
parent 11 06b8e2af4411
child 15 1f895d8a5b2b
--- a/qtmobility/plugins/contacts/qtcontacts-tracker/trackerchangelistener.cpp	Fri Jun 11 14:26:25 2010 +0300
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,161 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
-** All rights reserved.
-** Contact: Nokia Corporation (qt-info@nokia.com)
-**
-** This file is part of the Qt Mobility Components.
-**
-** $QT_BEGIN_LICENSE:LGPL$
-** No Commercial Usage
-** This file contains pre-release code and may not be distributed.
-** You may use this file in accordance with the terms and conditions
-** contained in the Technology Preview License Agreement accompanying
-** this package.
-**
-** GNU Lesser General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU Lesser
-** General Public License version 2.1 as published by the Free Software
-** Foundation and appearing in the file LICENSE.LGPL included in the
-** packaging of this file.  Please review the following information to
-** ensure the GNU Lesser General Public License version 2.1 requirements
-** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
-**
-** In addition, as a special exception, Nokia gives you certain additional
-** rights.  These rights are described in the Nokia Qt LGPL Exception
-** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
-**
-** If you have questions regarding the use of this file, please contact
-** Nokia at qt-info@nokia.com.
-**
-**
-**
-**
-**
-**
-**
-**
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-
-#include <QtTracker/ontologies/nco.h>
-
-#include "trackerchangelistener.h"
-#include "qcontact.h"
-
-using namespace SopranoLive;
-
-TrackerChangeListener::TrackerChangeListener(QContactManagerEngine *eng, QObject* parent) :
-    QObject(parent), engine(eng)
-{
-    signaler_contact = SopranoLive::BackEnds::Tracker::ClassUpdateSignaler::get(nco::Contact::iri());
-    if (signaler_contact)
-    {
-        SopranoLive::BackEnds::Tracker::ClassUpdateSignaler * signaler = signaler_contact;
-        connect(signaler, SIGNAL(subjectsAdded(const QStringList &)), SLOT(contactsAdded(const QStringList &)));
-        connect(signaler,SIGNAL(subjectsRemoved(const QStringList &)),SLOT(contactsRemoved(const QStringList &)));
-        connect(signaler,SIGNAL(subjectsChanged(const QStringList &)),SLOT(contactsChanged(const QStringList &)));
-    }
-
-    signaler_imaccount = SopranoLive::BackEnds::Tracker::ClassUpdateSignaler::get(nco::IMAccount::iri());
-    if (signaler_imaccount)
-    {
-        // same for all signals - emit selfContact changed
-        SopranoLive::BackEnds::Tracker::ClassUpdateSignaler * signaler = signaler_imaccount;
-        connect(signaler, SIGNAL(subjectsAdded(const QStringList &)),SLOT(imAccountsChanged(const QStringList &)));
-        connect(signaler,SIGNAL(subjectsRemoved(const QStringList &)),SLOT(imAccountsChanged(const QStringList &)));
-        connect(signaler,SIGNAL(subjectsChanged(const QStringList &)),SLOT(imAccountsChanged(const QStringList &)));
-    }
-
-    signaler_imaddress = SopranoLive::BackEnds::Tracker::ClassUpdateSignaler::get(nco::IMAddress::iri());
-    if (signaler_imaddress)
-    {
-        // same for all signals - contact changed to be emitted
-        SopranoLive::BackEnds::Tracker::ClassUpdateSignaler * signaler = signaler_imaddress;
-        connect(signaler, SIGNAL(subjectsAdded(const QStringList &)),SLOT(imAddressesChanged(const QStringList &)));
-        connect(signaler,SIGNAL(subjectsRemoved(const QStringList &)),SLOT(imAddressesChanged(const QStringList &)));
-        connect(signaler,SIGNAL(subjectsChanged(const QStringList &)),SLOT(imAddressesChanged(const QStringList &)));
-    }
-
-}
-
-TrackerChangeListener::~TrackerChangeListener()
-{
-    if (signaler_imaddress)
-        signaler_imaddress->disconnect(this);
-    if (signaler_contact)
-        signaler_contact->disconnect(this);
-    if (signaler_imaccount)
-        signaler_imaccount->disconnect(this);
-}
-
-QContactLocalId url2UniqueId(const QString &contactUrl)
-{
-    /* handle conatact:interger URL types comming from
-       which are non telepathy url's
-    */
-    QRegExp rx("(\\d+)");
-    bool conversion = false;
-    QContactLocalId id = 0;
-    if( rx.indexIn(contactUrl) != -1 )
-    {
-        id = rx.cap(1).toUInt(&conversion, 10);
-    }
-    if( !conversion )
-        qWarning() << Q_FUNC_INFO << "unparsed uri to uniqueI:" << contactUrl;
-    return id;
-}
-
-void TrackerChangeListener::contactsAdded(const QStringList &subjects)
-{
-    QList<QContactLocalId> added;
-    foreach(const QString &uri, subjects)
-    {
-        added << url2UniqueId(uri);
-    }
-    emit contactsAdded(added);
-}
-
-void TrackerChangeListener::contactsRemoved(const QStringList &subjects)
-{
-    QList<QContactLocalId> added;
-    foreach(const QString &uri, subjects)
-    {
-        added << url2UniqueId(uri);
-    }
-    emit contactsRemoved(added);
-}
-
-
-void TrackerChangeListener::contactsChanged(const QStringList &subjects)
-{
-    QList<QContactLocalId> changed;
-    foreach(const QString &uri, subjects) {
-        QContactLocalId id = url2UniqueId(uri);
-        if (changed.contains(id) == false) {
-            changed << id;
-        }
-    }
-    emit contactsChanged(changed);
-}
-
-void TrackerChangeListener::imAccountsChanged(const QStringList &subjects)
-{
-    Q_UNUSED(subjects)
-    QContactManager::Error error;
-    QContactLocalId selfId = engine->selfContactId(&error);
-    if (engine && QContactManager::NoError == error) {
-        emit contactsChanged(QList<QContactLocalId>()<<selfId);
-    } else {
-        qWarning() << __PRETTY_FUNCTION__ << "Signal not propagated:" << engine << error;
-    }
-}
-
-void TrackerChangeListener::imAddressesChanged(const QStringList &subjects)
-{
-    Q_UNUSED(subjects)
-    // TODO use QHash in engine - mapping IMAddress URIs to contacts
-    qWarning() << __PRETTY_FUNCTION__ << "Not implemented";
-}