inputmethods_pub/ptiengine_iti_api/inc/PtiCompositionDataIF.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 27 Apr 2010 16:59:43 +0300
branchRCL_3
changeset 9 e6a39382bb9c
parent 0 eb1f2e154e89
permissions -rw-r--r--
Revision: 201015 Kit: 201017

/*
* Copyright (c) 2003 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:               MPtiEngineCompositionDataInterface class definitions.
*
*/















#ifndef MPTIENGINECOMPOSITIONDATAINTERFACE_H
#define MPTIENGINECOMPOSITIONDATAINTERFACE_H

// INCLUDES
#include <e32base.h>
#include <badesca.h> 

// CLASS DECLARATION

/**
* MPtiEngineCompositionDataInterface class.
*  This is a class which returned by CPtiEngine::CompositionData() API.
*
*  @lib PtiEngine.lib
*  @since 2.6
*/
class MPtiEngineCompositionDataInterface
    {
    public:
        // the attribute of phrase
        enum TPtiAttributeOfPhrase
            {
            EPtiAttributeTransitoryInput,  // transitory input(before converting)
            EPtiAttributeNonTargetConvert, // non-target phrase(while converting)
            EPtiAttributeTargetConvert     // target phrase(while converting)
            };

    public:
        /**
        * Gets a cursor position on converting string
        * @since 2.6
        * @return TInt : The current cursor position
        *         If the cursor is left side, the returned value is 0.
        */
        IMPORT_C virtual TInt   CursorPosition() const = 0;

        /**
        * Gets the number of phrases on converting string
        * @since 2.6
        * @return TInt : the number of phrases
        */
        IMPORT_C virtual TInt   NumberOfPhrase() const = 0;

        /**
        * Gets the character count of each phrase
        * @since 2.6
        * @return TPtrC8 : the arrary keeping the character count
        */
        IMPORT_C virtual TPtrC8 LengthOfPhrase() const = 0;

        /**
        * Gets the attribute of each phrase
        * @since 2.6
        * @return TPtrC8 : the arrary keeping the value of TPtiAttributeOfPhrase
        */
        IMPORT_C virtual TPtrC8 AttributeOfPhrase() const = 0;

        /**
        * Gets the converting string
        * @since 2.6
        * @return TPtrC : the converting string
        */
        IMPORT_C virtual TPtrC  ConvertingString() const = 0;

        /**
        * Gets the specified string
        * @since 2.6
        * @return TPtrC : the completed string
        */
        IMPORT_C virtual TPtrC  CompletedString() const = 0;

        /**
        * Gets the reading string of the completed string
        * @since 2.6
        * @return TPtrC : the reading string
        */
        IMPORT_C virtual TPtrC  ReadingString() const = 0;

        /**
        * Checking it whether a character in a current cursor position 
        * is in modifiable character.
        * The modifiable character is diacritics and small characters.
        * There are two diacritics marks in Japanese: viced sound mark
        * and semi-voiced sound mark.
        * @since 2.6
        * @return TBool : ETrue is modifiable character.
        */
        IMPORT_C virtual TBool IsModifiableCharacter() const = 0;
    };

#endif  // MPTIENGINECOMPOSITIONDATAINTERFACE_H

// End of file