persistentstorage/sql/SRC/Common/SqlUtil.inl
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 09 Jun 2010 11:36:09 +0300
branchRCL_3
changeset 24 b6ab70c1385f
parent 0 08ec8eefde2f
permissions -rw-r--r--
Revision: 201023 Kit: 2010123

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

/**
 
 SQL server message code maker.
 
 The function accepts as arguments the server function code, handle type and handle,
 and makes from them a 32-bit value, which is used as a function code in RMessage2 objects.
 
 @param aFunction   function code
 @param aHandleType handle type - one of TSqlSrvHandleType enum item values
 @param aHandle     handle
 
 @return The assembled from aFunction, aHandleType and aHandle message code which will be sent
 to the SQL server.
 
 @see RMessage2
 @see TSqlSrvFunction
 
 @internalComponent
*/
inline TInt MakeMsgCode(TSqlSrvFunction aFunction, TSqlSrvHandleType aHandleType, TInt aHandle)
	{
	return (aHandleType | (aHandle << KSqlSrvHandleShiftBits) | aFunction);
	}

////////////////////////////////////////////////////////////////////////////////////////////////////////
//////////                  Case insensitive string comparisons                                     ////
////////////////////////////////////////////////////////////////////////////////////////////////////////

/**
Used for comparing database names, table names, column names and parameter names when the text encoding is UTF8.

@internalComponent
*/
inline TInt CompareNoCase8(const TDesC8& aLeft, const TDesC8& aRight)
	{
	return aLeft.CompareF(aRight);
	}
	
/**
Used for comparing database names, table names, column names and parameter names when the text encoding is UTF16.

@internalComponent
*/
inline TInt CompareNoCase16(const TDesC16& aLeft, const TDesC16& aRight)
	{
	return aLeft.CompareF(aRight);
	}

////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////////                      Buffer alignment functions                                     /////////////
////////////////////////////////////////////////////////////////////////////////////////////////////////////

/**
Returns aLen 8-byte aligned.

@param aLen Length value which needs alignment

@return 8-byte aligned aLen value

@internalComponent
*/
inline TInt AlignedLen8(TInt aLen)
	{
	return (aLen + 7) & (TUint32)~0x07;
	}
	
#ifdef _DEBUG
/**
Returns true if aLen is 8-byte aligned
The function is implemented only in _DEBUG releases.

@param aLen Length value which will be checked

@return True if aLen is 8-byte aligned

@internalComponent
*/
inline TBool IsAligned8(TInt aLen)
	{
	return (aLen & 0x07) == 0;	
	}
#endif