qtmobility/plugins/contacts/qtcontacts-tracker/trackerchangelistener.h
changeset 1 2b40d63a9c3d
child 4 90517678cc4f
equal deleted inserted replaced
0:cfcbf08528c4 1:2b40d63a9c3d
       
     1 /****************************************************************************
       
     2 **
       
     3 ** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
       
     4 ** All rights reserved.
       
     5 ** Contact: Nokia Corporation (qt-info@nokia.com)
       
     6 **
       
     7 ** This file is part of the Qt Mobility Components.
       
     8 **
       
     9 ** $QT_BEGIN_LICENSE:LGPL$
       
    10 ** No Commercial Usage
       
    11 ** This file contains pre-release code and may not be distributed.
       
    12 ** You may use this file in accordance with the terms and conditions
       
    13 ** contained in the Technology Preview License Agreement accompanying
       
    14 ** this package.
       
    15 **
       
    16 ** GNU Lesser General Public License Usage
       
    17 ** Alternatively, this file may be used under the terms of the GNU Lesser
       
    18 ** General Public License version 2.1 as published by the Free Software
       
    19 ** Foundation and appearing in the file LICENSE.LGPL included in the
       
    20 ** packaging of this file.  Please review the following information to
       
    21 ** ensure the GNU Lesser General Public License version 2.1 requirements
       
    22 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
       
    23 **
       
    24 ** In addition, as a special exception, Nokia gives you certain additional
       
    25 ** rights.  These rights are described in the Nokia Qt LGPL Exception
       
    26 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
       
    27 **
       
    28 ** If you have questions regarding the use of this file, please contact
       
    29 ** Nokia at qt-info@nokia.com.
       
    30 **
       
    31 **
       
    32 **
       
    33 **
       
    34 **
       
    35 **
       
    36 **
       
    37 **
       
    38 ** $QT_END_LICENSE$
       
    39 **
       
    40 ****************************************************************************/
       
    41 
       
    42 #ifndef TRACKERCHANGELISTENER_H_
       
    43 #define TRACKERCHANGELISTENER_H_
       
    44 
       
    45 #include <QObject>
       
    46 #include <QHash>
       
    47 #include <QSharedPointer>
       
    48 
       
    49 #include <QtTracker/QLive>
       
    50 #include <QtTracker/Tracker>
       
    51 
       
    52 #include <qmobilityglobal.h>
       
    53 #include <qcontact.h>
       
    54 
       
    55 QTM_USE_NAMESPACE
       
    56 
       
    57 QContactLocalId url2UniqueId(const QString &contactUrl);
       
    58 
       
    59 /*!
       
    60  * Helper class to handle multiple async queries at the same time inside TrackerChangeListener.
       
    61  * This class is designed to be generic, and initially used to get all contacts that correspond
       
    62  * to list of IMAccounts. When we get signal that multiple IMAccounts have changed, we read
       
    63  * all contacts and emit signal contacts changed for them.
       
    64  *
       
    65  * Usage: construct AsyncQuery with RDFSelect query. When signal queryReady(AsyncQuery *self)
       
    66  * is received, read data from rows in self->nodes (self-nodes()->rowCount() ...)
       
    67  *
       
    68  * Intention: The class has been created to wrap LiveNodes::modelUpdated signal,
       
    69  * and to know which query it corresponds to (not possible to fetch it from sender()).
       
    70  * \sa queryReady(AsyncQuery *)
       
    71  */
       
    72 class AsyncQuery: public QObject
       
    73 {
       
    74     Q_OBJECT
       
    75 public:
       
    76     AsyncQuery(SopranoLive::RDFSelect selectQuery);
       
    77     SopranoLive::LiveNodes nodes;
       
    78 
       
    79 private slots:
       
    80     void queryReady();
       
    81 signals:
       
    82     // emitted when modelUpdated() from LiveNodes related to selectQuery is received
       
    83     void queryReady(AsyncQuery *self);
       
    84 };
       
    85 
       
    86 /*!
       
    87  * \class TrackerChangeListener
       
    88  * \brief Translates signals from tracker and to contact signals
       
    89  * Listen for tracker signals, computes which contacts are and what si changed and emits
       
    90  * signals about contact change. Initially designed to compute change signals for
       
    91  * QContactTrackerEngine
       
    92  */
       
    93 class TrackerChangeListener : public QObject
       
    94 {
       
    95     Q_OBJECT
       
    96 public:
       
    97     TrackerChangeListener(QObject *parent=0);
       
    98     virtual ~TrackerChangeListener();
       
    99 
       
   100 signals:
       
   101     // signals are with the same semantics as in QContactManagerEngine
       
   102     void contactsAdded(const QList<QContactLocalId>& contactIds);
       
   103     void contactsChanged(const QList<QContactLocalId>& contactIds);
       
   104     void contactsRemoved(const QList<QContactLocalId>& contactIds);
       
   105 
       
   106 private slots:
       
   107     void subjectsAdded(const QStringList &subjects);
       
   108     void subjectsRemoved(const QStringList &subjects);
       
   109     void subjectsChanged(const QStringList &subjects);
       
   110 private:
       
   111     SopranoLive::BackEnds::Tracker::ClassUpdateSignaler *signaler_contact;
       
   112     SopranoLive::BackEnds::Tracker::ClassUpdateSignaler *signaler_imaccount;
       
   113 
       
   114     void connectSignals(SopranoLive::BackEnds::Tracker::ClassUpdateSignaler *signaler);
       
   115 
       
   116     QHash<AsyncQuery*, QSharedPointer<AsyncQuery> > pendingQueries;
       
   117 };
       
   118 
       
   119 
       
   120 #endif /* TRACKERCHANGELISTENER_H_ */