qtmobileextensions/src/keycapture/responsehandlerex.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 31 Aug 2010 16:02:37 +0300
branchRCL_3
changeset 9 5d007b20cfd0
permissions -rw-r--r--
Revision: 201033 Kit: 201035

/*
 * Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
 * All rights reserved.
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, version 2.1 of the License.
 * 
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program.  If not, 
 * see "http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html/".
 *
 * Description:
 *
 */

#ifndef RESPONSEHANDLEREX_H_
#define RESPONSEHANDLEREX_H_

#include <remconcoreapitarget.h>

#include <remconcoreapi.h>
#include <remconinterfaceselector.h>
#include <remconcallhandlingtarget.h>
#include <remconcallhandlingtargetobserver.h>    

NONSHARABLE_CLASS(CResponseHandlerEx) : public CActive
{
public:

    /**
     * Two-phased constructor.
     *
     * @since 3.0
     * @param aRemConCoreApiTarget RemCon core target object.
     * @return Pointer to newly created object.
     */
    static CResponseHandlerEx* NewL( CRemConCallHandlingTarget& aRemConCallHandlingTarget );

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

    /**
     * Send the any key response back to Remcon server
     *
     * @since 3.0
     * @param aOperationId RemCon operation Id.
     */
    void CompleteAnyKey(int id );

private:

    /**
     * C++ default constructor.
     */
    CResponseHandlerEx( CRemConCallHandlingTarget& aRemConCallHandlingTarget );

// from base class CActive

    /**
     * From CActive
     * Handles an active object's request completion event.
     */
    void RunL();

    /**
     * From CActive
     * Implements cancellation of an outstanding request.
     */
    void DoCancel();

private:    // Data

    // Response array.
    RArray<int> iResponseArray;   // Own
    CRemConCallHandlingTarget& iRemConCallHandlingTarget;         // Not own
};

#endif /* RESPONSEHANDLEREX_H__H_ */