qtmobility/plugins/contacts/symbian/tsrc/ut_symbian/mock_cntdb.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 11 Jun 2010 14:26:25 +0300
changeset 11 06b8e2af4411
parent 1 2b40d63a9c3d
permissions -rw-r--r--
Revision: 201021 Kit: 2010123

/****************************************************************************
**
** 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$
**
****************************************************************************/

#ifndef MOCK_CNTD_H
#define MOCK_CNTD_H

enum TContactDbObserverEventType
    {
    /** Null event type. */
    EContactDbObserverEventNull,
    /** Not currently used. */
    EContactDbObserverEventUnused,
    /** A contact item (not a template, group or own card) has been changed. */
    EContactDbObserverEventContactChanged,
    /** A contact item (not a template, group or own card) has been deleted. */
    EContactDbObserverEventContactDeleted,
    /** A contact item (not a template or group) has been added. */
    EContactDbObserverEventContactAdded,
    /** Unknown change event type. */
    EContactDbObserverEventUnknownChanges,
    /** Recover from a damaged database. */
    EContactDbObserverEventRecover,
    /** Rollback from a change to the database. */
    EContactDbObserverEventRollback,
    /** Database tables closed. */
    EContactDbObserverEventTablesClosed,
    /** Database tables opened. */
    EContactDbObserverEventTablesOpened,
    /** A contact card template has changed. */
    EContactDbObserverEventTemplateChanged,
    /** A contact card template has been deleted. */
    EContactDbObserverEventTemplateDeleted, 
    /** A contact card template has been added. */
    EContactDbObserverEventTemplateAdded,
    /** The database's current item has been deleted. */
    EContactDbObserverEventCurrentItemDeleted,
    /** The database's current item has changed. */
    EContactDbObserverEventCurrentItemChanged,
    /** The database's own card has changed. */
    EContactDbObserverEventOwnCardChanged,
    /** The database's preferred template has been set. (See CContactDatabase::SetPrefTemplateL()). */
    EContactDbObserverEventPreferredTemplateChanged,
    /** An own card has been deleted from the database. */
    EContactDbObserverEventOwnCardDeleted,
    /** A contact item group has been added. */
    EContactDbObserverEventGroupAdded,
    /** A contact item group has been updated. */
    EContactDbObserverEventGroupChanged,
    /** A contact item group has been deleted from the database. */
    EContactDbObserverEventGroupDeleted,
    /** The current database has changed. */
    EContactDbObserverEventCurrentDatabaseChanged,
    /** The phone number assigned to one of the speed dial positions 
    has been replaced, removed or modified.*/
    EContactDbObserverEventSpeedDialsChanged, 
    /** Not currently used. */
    EContactDbObserverEventSortOrderChanged,
    /** Contacts DB about to be backed up  */
    EContactDbObserverEventBackupBeginning,
    /** Contacts DB about to be restored */
    EContactDbObserverEventRestoreBeginning,
    /** The backup/restore operation has completed. */
    EContactDbObserverEventBackupRestoreCompleted,
    /** The restore operation has completed but the database could not be opened. */
    EContactDbObserverEventRestoreBadDatabase,
    /** Database has been compressed. */
    EContactDbObserverEventCompress
    };

typedef long int TContactItemId;

struct TContactDbObserverEvent
{
    TContactDbObserverEventType iType;
    TContactItemId iContactId;
};

class MContactDbObserver
{
public:
    virtual void HandleDatabaseEventL(TContactDbObserverEvent aEvent)=0;
};

class CContactDatabase
{
public:
    CContactDatabase(){};
    ~CContactDatabase(){}
    static CContactDatabase* OpenL();
    static CContactDatabase* CreateL();
    void AddObserverL(MContactDbObserver& aObserver);
    void RemoveObserver(MContactDbObserver& /*aObserver*/){};
    TContactItemId OwnCardId() const{return TContactItemId(12);};
    void sendEventsL(); // test HandleDatabaseEventL
private:
    MContactDbObserver *iObserver;
};

class CContactChangeNotifier
{
public:
    CContactChangeNotifier(CContactDatabase& aDbase, MContactDbObserver* aObserver);
    static CContactChangeNotifier* NewL(CContactDatabase& aDatabase, MContactDbObserver *aObserver);
    ~CContactChangeNotifier(){};
private:
    CContactDatabase *iDbase;
};

#endif //MOCK_CNTD_H