remotecontrol/remotecontrolfw/server/inc/messagequeue.h
author hgs
Wed, 13 Oct 2010 16:20:29 +0300
changeset 51 20ac952a623c
permissions -rw-r--r--
201040_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
51
20ac952a623c 201040_02
hgs
parents:
diff changeset
     1
// Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies).
20ac952a623c 201040_02
hgs
parents:
diff changeset
     2
// All rights reserved.
20ac952a623c 201040_02
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
20ac952a623c 201040_02
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
20ac952a623c 201040_02
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
20ac952a623c 201040_02
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
20ac952a623c 201040_02
hgs
parents:
diff changeset
     7
//
20ac952a623c 201040_02
hgs
parents:
diff changeset
     8
// Initial Contributors:
20ac952a623c 201040_02
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    10
//
20ac952a623c 201040_02
hgs
parents:
diff changeset
    11
// Contributors:
20ac952a623c 201040_02
hgs
parents:
diff changeset
    12
//
20ac952a623c 201040_02
hgs
parents:
diff changeset
    13
// Description:
20ac952a623c 201040_02
hgs
parents:
diff changeset
    14
//
20ac952a623c 201040_02
hgs
parents:
diff changeset
    15
20ac952a623c 201040_02
hgs
parents:
diff changeset
    16
/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    17
 @file 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    18
 @internalComponent
20ac952a623c 201040_02
hgs
parents:
diff changeset
    19
*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    20
20ac952a623c 201040_02
hgs
parents:
diff changeset
    21
#include <bluetooth/logger.h>
20ac952a623c 201040_02
hgs
parents:
diff changeset
    22
#ifndef MESSAGEQUEUE_H
20ac952a623c 201040_02
hgs
parents:
diff changeset
    23
#define MESSAGEQUEUE_H
20ac952a623c 201040_02
hgs
parents:
diff changeset
    24
20ac952a623c 201040_02
hgs
parents:
diff changeset
    25
#include <e32base.h>
20ac952a623c 201040_02
hgs
parents:
diff changeset
    26
20ac952a623c 201040_02
hgs
parents:
diff changeset
    27
class CRemConMessage;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    28
20ac952a623c 201040_02
hgs
parents:
diff changeset
    29
/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    30
A queue for RemCon messages (commands and responses). 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    31
Owns the messages.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    32
*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    33
NONSHARABLE_CLASS(CMessageQueue) : public CBase 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    34
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
    35
public:
20ac952a623c 201040_02
hgs
parents:
diff changeset
    36
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    37
	@return Ownership of a new CMessageQueue object.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    38
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    39
	static CMessageQueue* NewL();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    40
20ac952a623c 201040_02
hgs
parents:
diff changeset
    41
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    42
	Destructor.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    43
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    44
	~CMessageQueue();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    45
20ac952a623c 201040_02
hgs
parents:
diff changeset
    46
public:
20ac952a623c 201040_02
hgs
parents:
diff changeset
    47
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    48
	Accessor for a member iterator over the queue. The iterator is provided 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    49
	set to the first item in the queue. The iterator is 'safe' (will not be 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    50
	otherwise interfered with) until SetToFirst or the destructor is called. 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    51
	@return Iterator.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    52
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    53
	TSglQueIter<CRemConMessage>& SetToFirst();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    54
20ac952a623c 201040_02
hgs
parents:
diff changeset
    55
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    56
	Appends the given item at the end of the queue.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    57
	@param aMsg New message.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    58
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    59
	void Append(CRemConMessage& aMsg); 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    60
20ac952a623c 201040_02
hgs
parents:
diff changeset
    61
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    62
	Removes the given item from the queue and destroys it.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    63
	@param aMsg Message to be destroyed.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    64
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    65
	void RemoveAndDestroy(CRemConMessage& aMsg);
20ac952a623c 201040_02
hgs
parents:
diff changeset
    66
20ac952a623c 201040_02
hgs
parents:
diff changeset
    67
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    68
	Removes and destroys all messages belonging to the given session.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    69
	@param aSessionId ID of session.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    70
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    71
	void RemoveAndDestroy(TUint aSessionId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
    72
20ac952a623c 201040_02
hgs
parents:
diff changeset
    73
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    74
	Removes the given item from the queue without destroying it.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    75
	@param aMsg Message to be removed.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    76
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    77
	void Remove(CRemConMessage& aMsg);
20ac952a623c 201040_02
hgs
parents:
diff changeset
    78
20ac952a623c 201040_02
hgs
parents:
diff changeset
    79
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    80
	Returns the first item in the queue. The queue must not be empty. 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    81
	@return First item in the queue.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    82
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    83
	CRemConMessage& First();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    84
20ac952a623c 201040_02
hgs
parents:
diff changeset
    85
	/**
20ac952a623c 201040_02
hgs
parents:
diff changeset
    86
	Returns a message with a specified transaction ID
20ac952a623c 201040_02
hgs
parents:
diff changeset
    87
	@param Transaction ID of the required message
20ac952a623c 201040_02
hgs
parents:
diff changeset
    88
	@return Pointer to the message, or NULL if it does not exist. Ownership is retained by the queue
20ac952a623c 201040_02
hgs
parents:
diff changeset
    89
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    90
	
20ac952a623c 201040_02
hgs
parents:
diff changeset
    91
	CRemConMessage* Message(TUint aTransactionId);
20ac952a623c 201040_02
hgs
parents:
diff changeset
    92
	
20ac952a623c 201040_02
hgs
parents:
diff changeset
    93
	/** 
20ac952a623c 201040_02
hgs
parents:
diff changeset
    94
	@return Whether the queue is empty or not.
20ac952a623c 201040_02
hgs
parents:
diff changeset
    95
	*/
20ac952a623c 201040_02
hgs
parents:
diff changeset
    96
	inline TBool IsEmpty() const;
20ac952a623c 201040_02
hgs
parents:
diff changeset
    97
20ac952a623c 201040_02
hgs
parents:
diff changeset
    98
	inline TSglQue<CRemConMessage>& Queue();
20ac952a623c 201040_02
hgs
parents:
diff changeset
    99
20ac952a623c 201040_02
hgs
parents:
diff changeset
   100
	void LogQueue() const;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   101
	
20ac952a623c 201040_02
hgs
parents:
diff changeset
   102
private:
20ac952a623c 201040_02
hgs
parents:
diff changeset
   103
	CMessageQueue();
20ac952a623c 201040_02
hgs
parents:
diff changeset
   104
20ac952a623c 201040_02
hgs
parents:
diff changeset
   105
private: // owned
20ac952a623c 201040_02
hgs
parents:
diff changeset
   106
	TSglQue<CRemConMessage> iQueue;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   107
	TSglQueIter<CRemConMessage> iIter;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   108
	// Used for logging purposes.
20ac952a623c 201040_02
hgs
parents:
diff changeset
   109
	TUint iCount;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   110
	};
20ac952a623c 201040_02
hgs
parents:
diff changeset
   111
20ac952a623c 201040_02
hgs
parents:
diff changeset
   112
// Inlines
20ac952a623c 201040_02
hgs
parents:
diff changeset
   113
20ac952a623c 201040_02
hgs
parents:
diff changeset
   114
TBool CMessageQueue::IsEmpty() const
20ac952a623c 201040_02
hgs
parents:
diff changeset
   115
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   116
#ifdef __FLOG_ACTIVE
20ac952a623c 201040_02
hgs
parents:
diff changeset
   117
	// Needs to be defined locally to prevent redefinition
20ac952a623c 201040_02
hgs
parents:
diff changeset
   118
	_LIT8(KLogComponent, LOG_COMPONENT_REMCON_SERVER);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   119
#endif
20ac952a623c 201040_02
hgs
parents:
diff changeset
   120
20ac952a623c 201040_02
hgs
parents:
diff changeset
   121
	LOG_FUNC;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   122
	
20ac952a623c 201040_02
hgs
parents:
diff changeset
   123
	TBool ret = iQueue.IsEmpty();
20ac952a623c 201040_02
hgs
parents:
diff changeset
   124
	LOG1(_L("\tret = %d"), ret);
20ac952a623c 201040_02
hgs
parents:
diff changeset
   125
20ac952a623c 201040_02
hgs
parents:
diff changeset
   126
	return ret;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   127
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   128
20ac952a623c 201040_02
hgs
parents:
diff changeset
   129
TSglQue<CRemConMessage>& CMessageQueue::Queue()
20ac952a623c 201040_02
hgs
parents:
diff changeset
   130
	{
20ac952a623c 201040_02
hgs
parents:
diff changeset
   131
	return iQueue;
20ac952a623c 201040_02
hgs
parents:
diff changeset
   132
	}
20ac952a623c 201040_02
hgs
parents:
diff changeset
   133
20ac952a623c 201040_02
hgs
parents:
diff changeset
   134
#endif // MESSAGEQUEUE_H