textinput/peninputgenericitut/src/peninputgenericitutconverter.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 15 Jul 2010 19:01:13 +0300
branchRCL_3
changeset 18 b1ea1642412e
parent 0 eb1f2e154e89
permissions -rw-r--r--
Revision: 201025 Kit: 2010127

/*
* Copyright (c) 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:
*
*/
#include "peninputgenericitutconverter.h"

const TUint16 KSegment = 0x0020;

TInt TItutDataConverter::AnyToInt(TAny* aOriginal)
    {
    return *(reinterpret_cast<TInt*>(aOriginal));
    }
    
TRect TItutDataConverter::AnyToRect(TAny* aOriginal)
    {
    return *(reinterpret_cast<TRect*>(aOriginal));
    }
    
CFont* TItutDataConverter::AnyToFont(TAny* aOriginal)
    {
    return reinterpret_cast<CFont*>(aOriginal);
    }
    
TPoint TItutDataConverter::AnyToPoint(TAny* aOriginal)
    {
    return *(reinterpret_cast<TPoint*>(aOriginal));
    }
    
TRgb TItutDataConverter::AnyToRgb(TAny* aOriginal)
    {
    return *(reinterpret_cast<TRgb*>(aOriginal));
    }
    
TSize TItutDataConverter::AnyToSize(TAny* aOriginal)
    {
    return *(reinterpret_cast<TSize*>(aOriginal));
    }
    
RPointerArray<HBufC>& TItutDataConverter::AnyToRptrArray(TAny* aOriginal)    
    {
    return *(reinterpret_cast<RPointerArray<HBufC>*>(aOriginal));
    }

RArray<TRect>& TItutDataConverter::AnyToRectArray(TAny* aOriginal)
    {
    return *(reinterpret_cast<RArray<TRect>*>(aOriginal));
    }

TAknTextLineLayout TItutDataConverter::AnyToTextLine(TAny* aOriginal)
    {
    return *(reinterpret_cast<TAknTextLineLayout*>(aOriginal));
    }

void TItutDataConverter::ConvertChnPhraseCandidateL(const TDesC& aSource, 
                                                    RPointerArray<HBufC>& aList)
    {
    TInt start = 0;
    TInt length = 0;

    for (TInt ii = 0; ii < aSource.Length(); ii++)
        {
        if (aSource[ii] == KSegment)
            {
            TPtrC segment(aSource.Ptr() + start, length);
            aList.AppendL(segment.AllocL());
            start += (length + 1);
            length = 0;
            }
        else
            {
            length++;
            }
        }

    if (length)
        {
        TPtrC segm(aSource.Ptr() + start, length);
        aList.AppendL(segm.AllocL());
        }
    }

void TItutDataConverter::ConvertNonPhraseCandidateL(const TDesC& aSource, 
                                                    RPointerArray<HBufC>& aList)
    {
    TBuf<1> str;
    for (TInt ii = 0; ii < aSource.Length(); ii++)
        {
        str.Zero();
        str.Append(aSource[ii]);
        aList.AppendL(str.AllocL());
        }
    }

// End Of File