wim/Scard/inc/ScardMessageStack.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 26 Jan 2010 15:20:08 +0200
changeset 0 164170e6151a
permissions -rw-r--r--
Revision: 201004

/*
* Copyright (c) 2003 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:  Smart card message stack.
*
*/



#ifndef CSCARDMESSAGESTACK_H
#define CSCARDMESSAGESTACK_H

//  INCLUDES
#include "ScardServerBase.h"
#include "ScardClsv.h"
#include "ScardCommandTimer.h"
#include "ScardDefs.h"

// FORWARD DECLARATIONS
class CScardCommandTimer;

// CLASS DECLARATION

/**
*  Message stack.
*  This class establishes a connection with a SC reader handler for a session. 
*  Creates (if necessary) MScardReader objects, and determines when one of 
*  them satisfies the parameters.
*
*  @lib Scard.lib
*  @since Series60 2.1
*/
class CScardMessageStack : public CBase
    {
    public:  // Constructors and destructor

        /**
        * Two-phased constructor.
        */
        static CScardMessageStack* NewL();

        /**
        * Destructor.
        */
        virtual ~CScardMessageStack();
    
    public: // New functions 
        
        /**
        * Cancel all messages waiting for service. Delete all others 
        * except the first one.
        * @param aReason Reason code for cancellation
        * @return void
        */
        void CancelAll( const TInt aReason );
        
        /**
        * Cancel all operations for this session ID.
        * @param aSessionID Session ID
        * @param aReason Reason code for cancellation
        * @return void
        */
        void CancelAll( const TInt aSessionID,
                        const TInt aReason );

        /**
        * Effectively the same as CancelAll(const TInt aReason), 
        * except that does not cancel OpenReader commands.
        * @return void
        */
        void CancelCardOperations();

        /**
        * Cancels the messages using the given timer.
        * @param aTimer Timer object
        * @return void
        */
        void CancelByTimeOut( const CScardCommandTimer* aTimer );

        /**
        * Puts the message to the top of the stack.
        * @param aMessage Message
        * @return Error code
        */
        TInt PushToTop( const TMessageHandle& aMessage );

        /**
        * Puts the message to the bottom of the stack.
        * @param aMessage Message
        * @return Error code
        */
        TInt PushToBottom( const TMessageHandle& aMessage );

        /**
        * Returns the topmost message from the stack.
        * @return Handle to topmost message
        */
        const TMessageHandle FromTop();
        
        /**
        * This function is called when a channel is freed. It gives priority
        * for applications who are waiting to reserve either this channel 
        * or any channel.
        * @param aChannel Channel
        * @return Handle to message
        */        
        const TMessageHandle NextReservation( const TInt8 aChannel );

        /**
        * Returns the message from given position in the stack.
        * @param aPosition Position from which we want the message
        * @return Handle to message
        */ 
        const TMessageHandle FromPositionL( const TInt aPosition );

        /**
        * Push message to given position in the stack.
        * @param aPosition Position to which we want to push the msg
        * @param aHandle Message handle
        * @return Handle to message
        */
        void PushToPositionL( const TInt aPosition,
                              TMessageHandle& aHandle );

        /**
        * Returns the number of messages in the stack.
        * @return Count of messagages in the stack
        */
        inline const TInt Count();

    private:
        
        /**
        * C++ default constructor.
        */
        CScardMessageStack();
        
        /**
        * By default Symbian 2nd phase constructor is private.
        */
        void ConstructL();

        /**
        * Cancel one message
        * @param aIndex Index of message
        * @param aReason Reason code for cancellation
        * @param aCancelTimer Do we want to cancel timer
        * @return void
        */
        inline void CancelOne( const TInt aIndex,
                               const TInt aReason, 
                               const TBool aCancelTimer = ETrue );

    private:    // Data
        // Array of messages. Owned.
        CArrayFixFlat<TMessageHandle>* iMessages;
    };

#include "ScardMessageStack.inl"

#endif      // CSCARDMESSAGESTACK_H

// End of File