williamr@4: // Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies). williamr@4: // All rights reserved. williamr@4: // This component and the accompanying materials are made available williamr@4: // under the terms of "Eclipse Public License v1.0" williamr@4: // which accompanies this distribution, and is available williamr@4: // at the URL "http://www.eclipse.org/legal/epl-v10.html". williamr@4: // williamr@4: // Initial Contributors: williamr@4: // Nokia Corporation - initial contribution. williamr@4: // williamr@4: // Contributors: williamr@4: // williamr@4: // Description: williamr@4: // williamr@4: williamr@4: /** williamr@4: @file williamr@4: @internalTechnology williamr@4: */ williamr@4: williamr@4: #if !defined(__SS_FACT_INTERNAL_H__) williamr@4: #define __SS_FACT_INTERNAL_H__ williamr@4: williamr@4: #include williamr@4: #include williamr@4: williamr@4: namespace ESock williamr@4: { williamr@4: williamr@4: class CCommsFactoryBase; williamr@4: class ACommsFactoryNodeId; williamr@4: williamr@4: // We need to redeclare this for the CMetaConnectionProviderBase x86gcc cast operators to work. williamr@4: #ifndef __CCOMMSFACTORYCONTAINER_DECLARED williamr@4: #define __CCOMMSFACTORYCONTAINER_DECLARED williamr@4: NONSHARABLE_CLASS(CCommsFactoryContainer) : public Factories::CFactoryContainerNode williamr@4: /** Comms Factory Factory Container class is used to store comms factorys of a williamr@4: specific type. e.g. sub-connection provider factories. It provides basic williamr@4: functionality to find, add and remove factories. It has basic functionality to williamr@4: create a factory object. If a container wants to do more than just creating a williamr@4: factory object it should specialise the CCommsFactoryContainer williamr@4: williamr@4: @internalTechnology williamr@4: @released Since 9.0 */ williamr@4: { williamr@4: friend class CPitBoss; // CPitBoss enumerates factories without needing (or wanting) derived types williamr@4: williamr@4: #ifdef __X86GCC__ williamr@4: // gcc-mingw does not support declaring friends from different namespaces so we define proxy williamr@4: // functions to do the cast. williamr@4: friend CCommsFactoryContainer* __x86gcc_comms_factory_container_cast(Messages::ANode* aNode); williamr@4: friend CCommsFactoryContainer& __x86gcc_comms_factory_container_cast(Messages::ANode& aNode); williamr@4: #elif !defined(__GCCXML__) williamr@4: friend CCommsFactoryContainer* Messages::mnode_cast(Messages::ANode* aNode); williamr@4: #endif williamr@4: williamr@4: public: williamr@4: IMPORT_C Factories::CFactoryBase* FindOrCreateFactoryL(TUid aUid); williamr@4: IMPORT_C ACommsFactoryNodeId* Find (Factories::MFactoryQuery& aQuery); williamr@4: protected: williamr@4: Factories::CFactoryBase* CreateFactoryL(TUid aUid); williamr@4: ACommsFactoryNodeId* CreateFactoryObjectNodeL(Messages::TSignatureBase& aMessage); williamr@4: virtual void ReceivedL(const Messages::TRuntimeCtxId& aSender, const Messages::TNodeId& aRecipient, Messages::TSignatureBase& aMessage); williamr@4: williamr@4: protected: williamr@4: //Type information for the planes. williamr@4: enum TContaineeType williamr@4: { williamr@4: EUnknown = 0, williamr@4: ETierManagerFactoryContainer, williamr@4: EMetaConnectionFactoryContainer, williamr@4: EConnectionFactoryContainer, williamr@4: ESubConnectionFactoryContainer, williamr@4: ESubConnectionFlowFactoryContainer, williamr@4: EProtocolIntfFactoryContainer, williamr@4: EProtocolFamilyFactoryContainer, williamr@4: }; williamr@4: CCommsFactoryContainer(TContaineeType aId = EUnknown); williamr@4: public: williamr@4: const TContaineeType iId; williamr@4: williamr@4: public: williamr@4: static CCommsFactoryContainer* NewL (TContaineeType aId); williamr@4: }; williamr@4: #endif // __CCOMMSFACTORYCONTAINER_DECLARED williamr@4: williamr@4: williamr@4: class CCFFactoryContainerBroker : public Den::CCommonObjectBroker williamr@4: /** williamr@4: This object broker is intended to be a per technology singleton that forwards williamr@4: factory requests to a specified factory container. williamr@4: williamr@4: Factory containers are added to its client list during the handshaking at worker thread williamr@4: initialisation. williamr@4: williamr@4: @internalTechnology williamr@4: */ williamr@4: { williamr@4: public: williamr@4: static CCFFactoryContainerBroker* NewL(); williamr@4: williamr@4: protected: williamr@4: void ReceivedL(const Messages::TRuntimeCtxId& aSender, const Messages::TNodeId& aRecipient, Messages::TSignatureBase& aMessage); williamr@4: CCFFactoryContainerBroker(); williamr@4: }; williamr@4: williamr@4: #ifdef __X86GCC__ williamr@4: // gcc-mingw does not support declaring friends from different namespaces so we define proxy williamr@4: // functions to do the cast... williamr@4: williamr@4: inline CCommsFactoryContainer* __x86gcc_comms_factory_container_cast(Messages::ANode* aNode) williamr@4: { williamr@4: return static_cast(aNode); williamr@4: } williamr@4: williamr@4: inline CCommsFactoryContainer& __x86gcc_comms_factory_container_cast(Messages::ANode& aNode) williamr@4: { williamr@4: return static_cast(aNode); williamr@4: } williamr@4: #endif williamr@4: } williamr@4: williamr@4: williamr@4: #ifdef __X86GCC__ williamr@4: namespace Messages williamr@4: { williamr@4: // gcc-mingw does not support declaring friends from different namespaces so we define proxy williamr@4: // functions to do the cast... williamr@4: williamr@4: template <> williamr@4: inline ESock::CCommsFactoryContainer* mnode_cast(Messages::ANode* aNode) williamr@4: { williamr@4: return ESock::__x86gcc_comms_factory_container_cast(aNode); williamr@4: } williamr@4: williamr@4: template <> williamr@4: inline ESock::CCommsFactoryContainer& mnode_cast(Messages::ANode& aNode) williamr@4: { williamr@4: return ESock::__x86gcc_comms_factory_container_cast(aNode); williamr@4: } williamr@4: } williamr@4: #endif williamr@4: williamr@4: #endif williamr@4: // __SS_FACT_INTERNAL_H__