textandlocutils/jplangutil/inc/jplangutil.h
author hgs
Thu, 23 Sep 2010 12:50:02 +0800
changeset 64 f66674566702
parent 40 91ef7621b7fc
permissions -rw-r--r--
201033_08
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
40
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
     1
/*
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
     2
* Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies).
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
     3
* All rights reserved.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
     5
* under the terms of the License "Eclipse Public License v1.0"
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
     8
*
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
     9
* Initial Contributors:
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    11
*
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    12
* Contributors:
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    13
*
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    14
* Description: 
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    15
*     A utility for providing Japanese Language-specific (UNICODE) functions.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    16
*
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    17
*
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    18
*/
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    19
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    20
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    21
#ifndef __JPLANGUTIL_H__
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    22
#define __JPLANGUTIL_H__
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    23
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    24
// INCLUDES
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    25
#include <e32std.h>
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    26
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    27
// CONSTANTS
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    28
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    29
// CLASS DECLARATION
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    30
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    31
/**
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    32
 *  This is the only class provided buy the JPLangUtil Library,
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    33
 *  and is intended for encapsulation only.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    34
 *  As such, it should not be instantiated.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    35
 *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    36
 *  @lib JPLangUtil.lib
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    37
 *  @since 2.6
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    38
 */
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    39
class JPLangUtil
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    40
    {
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    41
    public: // Conversion API
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    42
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    43
        /**
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    44
        * Converts all Half-width conformant text (including ASCII, Special
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    45
        * Characters and Katakana) found in aUnicodeSource to their Full-width
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    46
        * counterparts and places the resulting text into aUnicodeTarget.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    47
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    48
        * @param aUnicodeSource Descriptor that contains the text to be
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    49
        *        converted.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    50
        * @param aUnicodeTarget The target descriptor for the converted text.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    51
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    52
        * @return Either a positive integer signifying the count of converted
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    53
        *         characters, or the negative error code KErrToBig when the
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    54
        *         target descriptor cannot hold all the converted text.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    55
        */
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    56
        IMPORT_C static TInt ConvertHalfToFullWidth
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    57
            (const TDesC16& aUnicodeSource, TDes16& aUnicodeTarget );
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    58
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    59
        /**
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    60
        * Converts all Full-width conformant text found in aUnicodeSource to
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    61
        * their Half-width counterparts and places the resulting text into
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    62
        * aUnicodeTarget. Only those characters with existing Half-width
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    63
        * variants are converted. There will be a 2-for-1 conversion for each
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    64
        * Full-width Voiced and Semi-voiced Katakana character.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    65
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    66
        * @param aUnicodeSource Descriptor that contains the text to be
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    67
        *        converted.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    68
        * @param aUnicodeTarget The target descriptor for the converted text.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    69
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    70
        * @return Either a positive integer signifying the count of converted
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    71
        *         characters, or the negative error code KErrToBig when the
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    72
        *         target descriptor cannot hold all the converted text.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    73
        */
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    74
        IMPORT_C static TInt ConvertFullToHalfWidth
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    75
            ( const TDesC16& aUnicodeSource, TDes16& aUnicodeTarget );
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    76
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    77
        /**
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    78
        * Converts Half-width Katakana and Special Character text found in
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    79
        * aUnicodeSource to their Full-width counterparts and places the
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    80
        * resulting text into aUnicodeTarget.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    81
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    82
        * @param aUnicodeSource Descriptor that contains the text to be
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    83
        *        converted.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    84
        * @param aUnicodeTarget The target descriptor for the converted text.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    85
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    86
        * @return Either a positive integer signifying the count of converted
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    87
        *         characters, or the negative error code KErrToBig when the
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    88
        *         target descriptor cannot hold all the converted text.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    89
        */
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    90
        IMPORT_C static TInt ConvertHalfToFullWidthKatakana
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    91
            ( const TDesC16& aUnicodeSource, TDes16& aUnicodeTarget );
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    92
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    93
        /**
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    94
        * Converts Full-width Katakana and Special Character text found in
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    95
        * aUnicodeSource to their Half-width counterparts and places the
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    96
        * resulting text into aUnicodeTarget. There will be a 2-for-1 conversion
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    97
        * for each Full-width Voiced and Semi-voiced Katakana character.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    98
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
    99
        * @param aUnicodeSource Descriptor that contains the text to be
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   100
        *        converted.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   101
        * @param aUnicodeTarget The target descriptor for the converted text.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   102
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   103
        * @return Either a positive integer signifying the count of converted
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   104
        *         characters, or the negative error code KErrToBig when the
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   105
        *         target descriptor cannot hold all the converted text.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   106
        */
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   107
        IMPORT_C static TInt ConvertFullToHalfWidthKatakana
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   108
            ( const TDesC16& aUnicodeSource, TDes16& aUnicodeTarget );
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   109
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   110
        /**
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   111
        * Converts Full-width Hiragana and Special Character text found in
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   112
        * aUnicodeSource to their Full-width counterparts and places the
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   113
        * resulting text into aUnicodeTarget.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   114
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   115
        * @param aUnicodeSource Descriptor that contains the text to be
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   116
        *        converted.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   117
        * @param aUnicodeTarget The target descriptor for the converted text.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   118
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   119
        * @return Either a positive integer signifying the count of converted
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   120
        *         characters, or the negative error code KErrToBig when the
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   121
        *         target descriptor cannot hold all the converted text.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   122
        */
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   123
        IMPORT_C static TInt ConvertFullHiragnaToFullKatakana
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   124
            ( const TDesC16& aUnicodeSource, TDes16& aUnicodeTarget );
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   125
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   126
    public: // Character Category Query API
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   127
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   128
        /**
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   129
        * Returns ETrue if aUnicodeChar is Katakana.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   130
        * This includes both Full and Half-width Katakana.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   131
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   132
        * @param aUnicodeChar The unicode character to test.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   133
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   134
        * @return Etrue : aUnicodeChar is Katakana
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   135
        */
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   136
        IMPORT_C static TBool IsKatakana( const TText aUnicodeChar );
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   137
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   138
        /**
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   139
        * Returns ETrue if aUnicodeChar is Hiragana.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   140
        * There are no Half-width Hiragana variants.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   141
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   142
        * @param aUnicodeChar The unicode character to test.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   143
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   144
        * @return Etrue : aUnicodeChar is Hiragana
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   145
        */
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   146
        IMPORT_C static TBool IsHiragana( const TText aUnicodeChar );
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   147
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   148
        /**
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   149
        * Returns ETrue if aUnicodeChar is Kanji, or CJK ideographic
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   150
        * All characters in the CJK ideographic range are Full-width.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   151
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   152
        * @param aUnicodeChar The unicode character to test.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   153
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   154
        * @return Etrue : aUnicodeChar is Kanji
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   155
        */
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   156
        IMPORT_C static TBool IsKanji( const TText aUnicodeChar );
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   157
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   158
        /**
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   159
        * Returns ETrue if aUnicodeChar is Half-width according to
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   160
        * the UNICODE definition of the term.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   161
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   162
        * @param aUnicodeChar The unicode character to test.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   163
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   164
        * @return Etrue : aUnicodeChar is Half-width
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   165
        */
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   166
        IMPORT_C static TBool IsHalfWidth( const TText aUnicodeChar );
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   167
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   168
        /**
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   169
        * Returns ETrue if aUnicodeChar is Full-width.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   170
        * Essentially, all text that is not Half-width.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   171
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   172
        * @param aUnicodeChar The unicode character to test.
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   173
        *
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   174
        * @return Etrue : aUnicodeChar is Full-width
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   175
        */
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   176
        IMPORT_C static TBool IsFullWidth( const TText aUnicodeChar );
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   177
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   178
    };
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   179
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   180
#endif //  __JPLANGUTIL_H__
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   181
91ef7621b7fc 201019_08
hgs
parents:
diff changeset
   182
// End of file