javaextensions/location/landmarks/inc/clapilmdatabaseeventnotifier.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 31 Aug 2010 15:09:22 +0300
branchRCL_3
changeset 25 ae942d28ec0e
parent 14 04becd199f91
permissions -rw-r--r--
Revision: v2.2.11 Kit: 201035

/*
* Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description:  Handles native landmark database events
 *
*/


#ifndef CLAPILMDATABASEEVENTNOTIFIER_H
#define CLAPILMDATABASEEVENTNOTIFIER_H

// INTERNAL INCLUDES
#include    "mlapilmdatabaseeventnotifier.h"

// EXTERNAL INCLUDES
#include    <e32std.h>
#include    <e32base.h>
#include    <EPos_Landmarks.h>

// FORWARD DECLARATIONS
class CPosLandmarkDatabase;
class MLAPILmDatabaseObserver;

/**
 * Handles native landmark database events
 *
 * The class monitors for the specified landmark database and notifies its
 * observers when a certain database event occurs. Currently, the notifier notifies
 * only when an event which is related to landmarks or categories occurs
 *
 * @lib N/A
 * @since S60 3.2
 */
NONSHARABLE_CLASS(CLAPILmDatabaseEventNotifier) : public CActive,
        public MLAPILmDatabaseEventNotifier
{
public: // Constructors and destructor

    /**
     * Two-phased constructor. Creates an instance from this class
     * The caller takes the ownership of the returned instance which
     * is left to the cleanup stack
     *
     * @param aDatabase The database which events this active object listens
     * @return New instance from this class
     */
    static CLAPILmDatabaseEventNotifier* NewLC(CPosLandmarkDatabase& aDatabase);

    /**
     * Destructor.
     */
    virtual ~CLAPILmDatabaseEventNotifier();

public: // From MLAPILmDatabaseEventNotifier

    /**
     * Adds an event observer to this notifier
     *
     * @param aObserver An event observer. This class does NOT take
     *        the ownership of the value
     */
    void AddObserverL(MLAPILmDatabaseObserver* aObserver);

    /**
     * Removes an event observer from this notifier. Nothing happens if
     * there is no such observer in the observer array
     *
     * @param aObserver An event observer. This class does NOT take
     *        the ownership of the value
     */
    void RemoveObserver(MLAPILmDatabaseObserver* aObserver);

    /**
     * Returns ETrue if event listening is supported. EFalse if the
     * Landmarks API does not support event listening
     */
    TBool IsEventListeningSupported();

protected: // From CActive

    /**
     * Called when a request has completed. Note that RunError is not
     * implemented because RunL is currently leave-safe
     */
    void RunL();

    /**
     * Called by the base class when this active object is canceled
     */
    void DoCancel();

protected: // Constructors

    /**
     * C++ constructor
     */
    CLAPILmDatabaseEventNotifier(CPosLandmarkDatabase& aDatabase);

private: // Data

    // The database which events this object listens. Used
    CPosLandmarkDatabase& iDatabase;
    // Array of database event observers. Used
    RPointerArray< MLAPILmDatabaseObserver> iEventObservers;
    // Event objects which holds the event and item id when
    // a request has completed.
    TPosLmEvent iEvent;

};

#endif // CLAPILMDATABASEEVENTNOTIFIER_H
// End of file