graphicsresourceservices/graphicsresource/inc/sgdriver.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 31 Aug 2010 16:31:06 +0300
branchRCL_3
changeset 163 bbf46f59e123
parent 0 5d03bc08d59c
permissions -rw-r--r--
Revision: 201029 Kit: 201035

// Copyright (c) 2008-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:
//

/**
 @file
 @internalComponent
*/

#ifndef SGDRIVER_H
#define SGDRIVER_H

#include <e32std.h>
#include <pls.h>


class MSgDriverAdapter;

/**
@internalComponent

This class encapsulates the global data in the Graphics Resource DLL.
*/
NONSHARABLE_CLASS(XSgDriverPls)
	{
public:
	/**
	Default constructor, called when the Graphics Resource DLL is loaded into a
	process. Creates the mutex used to synchronise access to the global data. The
	mutex will be automatically destroyed by the kernel on process termination.
	*/
	XSgDriverPls();
public:
	/**
	Result code of the constructor.
	*/
	TInt iError;
	/**
	Handle to the mutex used to synchronise access to the global data.
	*/
	RMutex iMutex;
#ifdef __WINS__
	/**
	Handle to the Graphics Resource Adapter DLL owned by this process.
	*/
	RLibrary iLibrary;
#endif
	/**
	Number of times SgDriver::Open() has been called from this process without
	a corresponding call to SgDriver::Close().
	*/
	TInt iOpenCount;
	/**
	Pointer to the Graphics Resource Adapter singleton in this process.
	*/
	MSgDriverAdapter* iDriver;
	};


/**
@internalComponent

The UID3 value in the compound identifier of the Graphics Resource DLL.
*/
const TUid KSgResourceLibraryUid = {0x10285A70};


/**
@internalComponent

The global data in the Graphics Resource DLL.
*/
#ifdef __WINS__
#define gPls (*Pls<XSgDriverPls>(KSgResourceLibraryUid))
#else
extern XSgDriverPls gPls;
#endif


#endif // SGDRIVER_H