persistentstorage/dbms/sdbms/SD_OBJ.CPP
author Shabe Razvi <shaber@symbian.org>
Tue, 19 Oct 2010 15:57:30 +0100
changeset 54 a0e1d366428c
parent 0 08ec8eefde2f
permissions -rw-r--r--
Workaround for Bug 3854 - featuremgr bld.inf no longer exports features.dat for emulator

// Copyright (c) 1998-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:
// DBMS server and support classes
// 
//

#include "SD_STD.H"

// Class RDbsObject
void RDbsObject::OpenL(const RDbsObject& aDbs,TDbsFunction aFunction,const TIpcArgs* aArgs)
	{
	__ASSERT(!iHandle);
	iHandle=aDbs.SendReceiveL(TDbsFunction(aFunction|KDbsObjectReturn),aArgs);
	RDbs::operator=(STATIC_CAST(const RDbs&,aDbs));
	}

void RDbsObject::Close()
	{
	if (iHandle)
		{
		SendReceive(EDbsClose);
		iHandle=0;
		SetHandle(KNullHandle);		// set session handle
		}
	}

TInt RDbsObject::SendReceive(TDbsFunction aFunction,const TIpcArgs* aArgs) const
	{
	__ASSERT(iHandle);
	if(aArgs)
		return RDbs::SendReceive(DbsMessage(aFunction,iHandle),*aArgs);
	else
		return RDbs::SendReceive(DbsMessage(aFunction,iHandle),TIpcArgs());
	}

TInt RDbsObject::SendReceive(TDbsFunction aFunction) const
	{
	return SendReceive(aFunction,0);
	}

TInt RDbsObject::SendReceiveL(TDbsFunction aFunction,const TIpcArgs* aArgs) const
	{
	return __LEAVE_IF_ERROR(SendReceive(aFunction,aArgs));
	}

TInt RDbsObject::SendReceiveL(TDbsFunction aFunction) const
	{
	return SendReceiveL(aFunction,0);
	}

void RDbsObject::SendReceive(TDbsFunction aFunction,const TIpcArgs* aArgs,TRequestStatus& aStatus) const
	{
	__ASSERT(iHandle);
	if(aArgs)
		RDbs::SendReceive(DbsMessage(aFunction,iHandle),*aArgs,aStatus);
	else
		RDbs::SendReceive(DbsMessage(aFunction,iHandle),TIpcArgs(),aStatus);
	}

// Class TDbsParam

const TInt KBufGranularity=0x200;

TPtrC8 TDbsParam::PrepareLC(const CDbColSet& aColSet)
	{
	CBufFlat* buf=CBufFlat::NewL(KBufGranularity);
	CleanupStack::PushL(buf);
	RBufWriteStream strm(*buf);
	strm<<aColSet;
	return buf->Ptr(0);
	}

TPtrC8 TDbsParam::PrepareLC(const CDbKey& aKey)
	{
	CBufFlat* buf=CBufFlat::NewL(KBufGranularity);
	CleanupStack::PushL(buf);
	RBufWriteStream strm(*buf);
	strm<<aKey;
	return buf->Ptr(0);
	}

TPtrC8 TDbsParam::PrepareLC(const TDbLookupKey& aKey)
	{
	TInt tsize=0;
	const TDbLookupKey::SColumn* iter=aKey.First();
	const TDbLookupKey::SColumn* end=iter+aKey.Count();
	do
		{
		switch (iter->iType)
			{
		default:
			break;
		case EDbColText8:
			tsize+=iter->iDes8.iLength;
			break;
		case EDbColText16:
			tsize+=iter->iDes16.iLength<<1;
			break;
			};
		} while (++iter<end);
	//
	TInt size=(TUint8*)end-(TUint8*)&aKey;
	TDbLookupKey* key=(TDbLookupKey*)User::AllocLC(size+tsize);
	TUint8* text=Mem::Copy(key,&aKey,size);
	if (tsize)
		{
		TDbLookupKey::SColumn* iter=CONST_CAST(TDbLookupKey::SColumn*,key->First());
		TDbLookupKey::SColumn* end=(TDbLookupKey::SColumn*)text;
		do
			{
			switch (iter->iType)
				{
			default:
				break;
			case EDbColText8:
				{
				const TUint8* p=iter->iDes8.iPtr;
				iter->iDes8.iPtr=REINTERPRET_CAST(const TUint8*,(text-(TUint8*)key));
				text=Mem::Copy(text,p,iter->iDes8.iLength);
				}
				break;
			case EDbColText16:
				{
				const TUint16* p=iter->iDes16.iPtr;
				iter->iDes16.iPtr=REINTERPRET_CAST(const TUint16*,(text-(TUint8*)key));
				text=Mem::Copy(text,p,iter->iDes16.iLength<<1);
				}
				break;
				};
			} while (++iter<end);
		}
	return TPtrC8((TUint8*)key,size+tsize);
	}