Bump version to 6.0-36
[LibreOffice.git] / i18npool / source / transliteration / ignoreIandEfollowedByYa_ja_JP.cxx
blobc23555a0b2b0dac500abc1a199ff00d9f30769db
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #include <i18nutil/oneToOneMapping.hxx>
22 #include <transliteration_Ignore.hxx>
24 using namespace com::sun::star::uno;
25 using namespace com::sun::star::lang;
27 namespace i18npool {
29 i18nutil::OneToOneMappingTable_t const IandE[] = {
30 { 0x30A3, 0x0000 }, // KATAKANA LETTER SMALL I
31 { 0x30A4, 0x0000 }, // KATAKANA LETTER I
32 { 0x30A7, 0x0000 }, // KATAKANA LETTER SMALL E
33 { 0x30A8, 0x0000 }, // KATAKANA LETTER E
34 { 0x30AD, 0x0000 }, // KATAKANA LETTER KI
35 { 0x30AE, 0x0000 }, // KATAKANA LETTER GI
36 { 0x30B1, 0x0000 }, // KATAKANA LETTER KE
37 { 0x30B2, 0x0000 }, // KATAKANA LETTER GE
38 { 0x30B7, 0x0000 }, // KATAKANA LETTER SI
39 { 0x30B8, 0x0000 }, // KATAKANA LETTER ZI
40 { 0x30BB, 0x0000 }, // KATAKANA LETTER SE
41 { 0x30BC, 0x0000 }, // KATAKANA LETTER ZE
42 { 0x30C1, 0x0000 }, // KATAKANA LETTER TI
43 { 0x30C2, 0x0000 }, // KATAKANA LETTER DI
44 { 0x30C6, 0x0000 }, // KATAKANA LETTER TE
45 { 0x30C7, 0x0000 }, // KATAKANA LETTER DE
46 { 0x30CB, 0x0000 }, // KATAKANA LETTER NI
47 { 0x30CD, 0x0000 }, // KATAKANA LETTER NE
48 { 0x30D2, 0x0000 }, // KATAKANA LETTER HI
49 { 0x30D3, 0x0000 }, // KATAKANA LETTER BI
50 { 0x30D4, 0x0000 }, // KATAKANA LETTER PI
51 { 0x30D8, 0x0000 }, // KATAKANA LETTER HE
52 { 0x30D9, 0x0000 }, // KATAKANA LETTER BE
53 { 0x30DA, 0x0000 }, // KATAKANA LETTER PE
54 { 0x30DF, 0x0000 }, // KATAKANA LETTER MI
55 { 0x30E1, 0x0000 }, // KATAKANA LETTER ME
56 { 0x30EA, 0x0000 }, // KATAKANA LETTER RI
57 { 0x30EC, 0x0000 }, // KATAKANA LETTER RE
58 { 0x30F0, 0x0000 }, // KATAKANA LETTER WI
59 { 0x30F1, 0x0000 }, // KATAKANA LETTER WE
60 { 0x30F6, 0x0000 }, // KATAKANA LETTER SMALL KE
61 { 0x30F8, 0x0000 }, // KATAKANA LETTER VI
62 { 0x30F9, 0x0000 } // KATAKANA LETTER VE
66 OUString SAL_CALL
67 ignoreIandEfollowedByYa_ja_JP::folding( const OUString& inStr, sal_Int32 startPos, sal_Int32 nCount, Sequence< sal_Int32 >& offset )
69 // Create a string buffer which can hold nCount + 1 characters.
70 // The reference count is 1 now.
71 rtl_uString * newStr = rtl_uString_alloc(nCount);
72 sal_Unicode * dst = newStr->buffer;
73 const sal_Unicode * src = inStr.getStr() + startPos;
75 sal_Int32 *p = nullptr;
76 sal_Int32 position = 0;
77 if (useOffset) {
78 // Allocate nCount length to offset argument.
79 offset.realloc( nCount );
80 p = offset.getArray();
81 position = startPos;
85 sal_Unicode previousChar = *src ++;
86 sal_Unicode currentChar;
88 // One to one mapping
89 i18nutil::oneToOneMapping aTable(IandE, sizeof(IandE));
91 // Translation
92 while (-- nCount > 0) {
93 currentChar = *src ++;
95 // the character listed in above table + YA --> the character + A
96 if (currentChar == 0x30E3 || // KATAKANA LETTER SMALL YA
97 currentChar == 0x30E4) { // KATAKANA LETTER YA
98 if (aTable[ previousChar ] != previousChar) {
99 if (useOffset) {
100 *p ++ = position++;
101 *p ++ = position++;
103 *dst ++ = previousChar;
104 *dst ++ = 0x30A2; // KATAKANA LETTER A
105 previousChar = *src ++;
106 nCount --;
107 continue;
111 if (useOffset)
112 *p ++ = position++;
113 *dst ++ = previousChar;
114 previousChar = currentChar;
117 if (nCount == 0) {
118 if (useOffset)
119 *p = position;
120 *dst ++ = previousChar;
123 *dst = u'\0';
125 newStr->length = sal_Int32(dst - newStr->buffer);
126 if (useOffset)
127 offset.realloc(newStr->length);
128 return OUString(newStr, SAL_NO_ACQUIRE); // take ownership
133 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */