--- 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";
-}