os/graphics/graphicsdeviceinterface/gdi/sgdi/BidiCopy.h
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
// Copyright (c) 2002-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
//
sl@0
    15
sl@0
    16
#ifndef BIDICOPY_H_
sl@0
    17
#define BIDICOPY_H_
sl@0
    18
sl@0
    19
#include <e32def.h>
sl@0
    20
sl@0
    21
class BidiCopy
sl@0
    22
/** Text copying and reversal routines.
sl@0
    23
@internalTechnology */
sl@0
    24
	{
sl@0
    25
public:
sl@0
    26
	static TInt Mirror(TInt a);
sl@0
    27
	static void ReverseCodes(TText* aText, TInt aLength);
sl@0
    28
	static TText* CopyBackwards(TText* aDestination,
sl@0
    29
		const TText* aSource, TInt aLength);
sl@0
    30
	static void DeleteUnreversedSurrogates(TText* aText, TInt aLength);
sl@0
    31
	static void CorrectSurrogatePairs(TText* aText, TInt aLength);
sl@0
    32
	static void CorrectGroups(TText* aText, TInt aLength);
sl@0
    33
	 static void SubstituteMirrorImages(TText* aText, TInt aLength);
sl@0
    34
	static TText* CopyMirror(TText* aDestination, const TText* aSource, TInt length);
sl@0
    35
	static TText* OutputTChar(TText* aDestination, TInt aToOutput);
sl@0
    36
	static TText* CopyBackwardsWithMirroring(TText* aDestination,
sl@0
    37
		const TText* aSource, TInt aLength);
sl@0
    38
	static TText* CopyGroupsBackwards(TText* aDestination,
sl@0
    39
		const TText* aSource, TInt aLength);
sl@0
    40
	static TBool ImplicitDirectionalityIsRightToLeft(
sl@0
    41
		const TText* aText, TInt aLength, TBool* aFound);
sl@0
    42
	};
sl@0
    43
sl@0
    44
#endif