dbgsrv/coredumpserver/interface/common/plugindata.h
author ravikurupati
Tue, 02 Mar 2010 10:33:16 +0530
changeset 0 c6b0df440bee
permissions -rw-r--r--
Initial contribution of EPL licensed sources

// Copyright (c) 2007-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:
// Defines ECOM-plugin related classes used accross the Core Dump client/server interface 
//



/**
 @file
 @publishedPartner 
 @released
*/

#ifndef PLUGINDATA_H
#define PLUGINDATA_H

/**
@publishedPartner 
@released

Class used between Core Dump Server and its clients to request 
the server to carry out actions on plugins, such as load/unload.
@see CCrashConfig::LoadPlugin()
*/
class TPluginRequest
{
public:

	
	inline TPluginRequest(){ iIndex = 0; }
	
	/** 
	Type of plugin to request
	*/
	enum TPluginType
		{
		/** A formatter plugin */
		EFormatter,
		/** A writer plugin */
		EWriter
		};


	/* Whether to load or unload the plugin */
	TBool						iLoad; 

	/** Type of plugin */
	TPluginType					iPluginType;

    /** Index of the plugin that requires action */
	TUint						iIndex;

	/** Plugin UID, used to check correct plugin */
	TUid						iUid;

    /** Index of the pair plugin */
	TUint                       iPair;

	/** @internalTechnology */
	TUint32 iSpare2;
};


/** Maximum length allowed for a plugin's name */
#define KPluginNameLength (50)

/** Maximum length allowed for a plugin's description */
#define KPluginDescriptionLength (250)

/**
@publishedPartner 
@released

Detailed information about a plugin.
@see RPluginList
@see TPluginInfoBlock
*/
class TPluginInfo
{
public:

	/** Plugin's own version.
	From rss file::IMPLEMENTATION_INFO::version_no */
	TUint					iVersion;

	/** Plugin's unique UID. 
	From rss file::IMPLEMENTATION_INFO::implementation_uid */
	TUid					iUid;

	/** Plugin's own name.
	From rss file::IMPLEMENTATION_INFO::display_name */
	TBufC<KPluginNameLength>			iName;

	/** Plugin's own description obtained from 
	CCoreDumpFormatter->GetDescription()
	@see CCoreDumpFormatter */
	TBufC<KPluginDescriptionLength>	iDescription;

	/** Plugin type : from TPluginRequest::TPluginType */
	TPluginRequest::TPluginType	iType;

	/** Plugin loaded state. */
	TBool					iLoaded;

	/** Reserved for future use
	@internalTechnology */
	TUint32 iSpare1;

	/** @internalTechnology */
	TUint32 iSpare2;
};


/**
@publishedPartner 
@released

List of TPluginInfo objects.
@see TPluginInfo
@see RArray
*/
typedef RArray<TPluginInfo>	RPluginList;


#include <streamelement.h>

/**
@publishedPartner 
@released

Class that represents a ECOM plugin instance. 
It is based on CStreamElementBase so it can be streamed between client and server.
@see CServerCrashDataSource::GetPluginListL
*/
class CPluginInfo : public CStreamElementBase
{

public:

	IMPORT_C static CPluginInfo* NewL( const TDesC &aName,
									   const TInt aUid,
                                       const TUint aVersion,
									   const TPluginRequest::TPluginType aType); 

	IMPORT_C static CPluginInfo* NewL( const TDesC8 & aStreamData );

	IMPORT_C ~CPluginInfo();

public:

	IMPORT_C void NameL( const TDesC & aName );
	IMPORT_C const TDesC & Name() const;

    IMPORT_C void Uid(const TInt aUid);
    IMPORT_C TInt Uid() const;

    IMPORT_C void Version(TUint aVersion);
    IMPORT_C TUint Version() const;

    IMPORT_C void Pair(TUint aIndex);
    IMPORT_C TUint Pair() const;

    IMPORT_C void Type(TPluginRequest::TPluginType aType);
    IMPORT_C TPluginRequest::TPluginType Type() const;

public:
	// Methods required by streaming interface 

	IMPORT_C TInt static MaxSize();

	IMPORT_C TInt Size() const;

	// Initializes ’this’ from stream
	IMPORT_C void InternalizeL( RReadStream & aStream );

	// Writes ’this’ to the stream
	IMPORT_C void ExternalizeL( RWriteStream & aStream, CBufFlat* buf );


private:

	CPluginInfo( const TInt aUid,
				 const TUint aVersion,
                 const TPluginRequest::TPluginType aType);

	CPluginInfo();

	void ConstructL( const TDesC & aName );

private:

    /** Plugin name */
	HBufC *iName;

    /** Plugin UID */
	TInt iUid;

    /** Plugin version */
	TUint iVersion;

	/** Plugin type : from TPluginRequest::TPluginType */
	TPluginRequest::TPluginType	iType;

    /** Index to paired plugin */
    TUint iPair;

	/** Externalized size */
	TUint				iSize;

	/** Reserved for future use
	@internalTechnology */
	TUint32 iSpare1;

	/** @internalTechnology */
	TUint32 iSpare2;

	};


/**
@publishedPartner 
@released

List of CPluginInfo object pointers
@see CPluginInfo
@see RPointerArray
*/
typedef RPointerArray<CPluginInfo>	RPluginPointerList;


#endif