datacommsserver/esockserver/inc/ss_nodemessages_tiermanagerfactory.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 14 Sep 2010 23:38:38 +0300
branchRCL_3
changeset 73 5ebd530e523b
parent 0 dfb7c4ff071f
permissions -rw-r--r--
Revision: 201035 Kit: 201035

// Copyright (c) 2005-2009 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:
// This file should be removed once FindOrCreateTM is removed by changes being made by subramanian
// THIS API IS INTERNAL TO NETWORKING AND IS SUBJECT TO CHANGE AND NOT FOR EXTERNAL USE
// 
//

/**
 @file
 @internalAll
*/

#ifndef SYMBIAN_NODEMESSAGES_TIERMANAGERFACTORY_H
#define SYMBIAN_NODEMESSAGES_TIERMANAGERFACTORY_H

#include <comms-infras/ss_nodemessages_factory.h>

namespace ESock
{


//any new enum added here needs to go into one of the utracedecoder definition files
//NEVER INSERT ANYTHING IN HERE ONLY ADD THE PENALTY IS SUDDEN DEATH!
class TCFTierManagerFactory //: public TCFFactory
	{
private:
	enum
	{
	ECFFindOrCreateTM               = 1 //new realm TTierManagerFactory. if tricky ignore till robs changes pulled in
	};
protected:

public:
    enum { ERealmId = 0x10285F53 }; //UID allocated on 4/6/08 from KUidNodeMessageRealms
    /*==========================================================================
    <<Keys:>>
    [Name]:      <messagename>
    [Semantics]: Message semantics

    [Type]:      Request for <responsemsg>|Response to <requestmsg>|Notification/[Peerless]
                 Where:
                 Request      - request to perform an action. Sender should expect <responsemsg>
                                to ackowledge the completion of the action.
                 Response     - acknowledgement that the previous request is now completed.
                 Notification - a one-off message flagging an event.
                 Peerless     - the message is peerless, i.e.: the sender doesn't have to
                                be the recipient's client.
    [Fallible]:  Yes|No
                 Only applicable to requests and denotes whether the request can fail or not,
                 or, in other words, whether the request can be completed to with TError.

    [Structure]:
    Every message defined in this realm has at least:
    param        iSender      - the message sender
    param        iActivityId  - depending on the message type:
                 Request      - the activity id the response should be addressed to.
                                Request senders fill up this param to match the response
                                with the local activity. Activity id on the sender side
                                should uniquelly identify the activity expecting the response.
                 Response     - the activity on the recipient side expecting this response.
                                the activityid to put here has been previously conveyed
                                with the request.
                 Notification - ignored.
    ===========================================================================*/

//--Factories--
    /*==========================================================================
    [Name]:      TFindOrCreateTM
    [Semantics]: Request sent to a factory container. The TierManager object is to
                 be preexisting or newly created.

    [Type]:      Request
    [Fallible]:  Yes

    [Structure]:
    param        iUid - UID of the top-most tier (used to initialise the new TM)
    ===========================================================================*/
	typedef Messages::TMessageSigUid<ECFFindOrCreateTM, TCFTierManagerFactory::ERealmId> TFindOrCreateTM;
	};
} //namespace esock

#endif
//SYMBIAN_NODEMESSAGES_TIERMANAGERFACTORY_H