office-gobmx/i18npool/source/transliteration/textToPronounce_zh.cxx
Luboš Luňák 1946794ae0 mass removal of rtl:: prefixes for O(U)String*
Modules sal, salhelper, cppu, cppuhelper, codemaker (selectively) and odk
have kept them, in order not to break external API (the automatic using declaration
is LO-internal).

Change-Id: I588fc9e0c45b914f824f91c0376980621d730f09
2013-04-07 14:23:11 +02:00

195 lines
5.3 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
* This file incorporates work covered by the following license notice:
*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright
* ownership. The ASF licenses this file to you under the Apache
* License, Version 2.0 (the "License"); you may not use this file
* except in compliance with the License. You may obtain a copy of
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
// prevent internal compiler error with MSVC6SP3
#include <utility>
#include <rtl/string.hxx>
#include <rtl/ustrbuf.hxx>
#define TRANSLITERATION_ALL
#include <textToPronounce_zh.hxx>
using namespace com::sun::star::uno;
namespace com { namespace sun { namespace star { namespace i18n {
sal_Int16 SAL_CALL TextToPronounce_zh::getType() throw (RuntimeException)
{
return TransliterationType::ONE_TO_ONE| TransliterationType::IGNORE;
}
const sal_Unicode* SAL_CALL
TextToPronounce_zh::getPronounce(const sal_Unicode ch)
{
static const sal_Unicode emptyString[]={0};
if (idx) {
sal_uInt16 address = idx[0][ch>>8];
if (address != 0xFFFF)
return &idx[2][idx[1][address + (ch & 0xFF)]];
}
return emptyString;
}
OUString SAL_CALL
TextToPronounce_zh::folding(const OUString & inStr, sal_Int32 startPos,
sal_Int32 nCount, Sequence< sal_Int32 > & offset) throw (RuntimeException)
{
OUStringBuffer sb;
const sal_Unicode * chArr = inStr.getStr() + startPos;
if (startPos < 0)
throw RuntimeException();
if (startPos + nCount > inStr.getLength())
nCount = inStr.getLength() - startPos;
offset[0] = 0;
for (sal_Int32 i = 0; i < nCount; i++) {
OUString pron(getPronounce(chArr[i]));
sb.append(pron);
if (useOffset)
offset[i + 1] = offset[i] + pron.getLength();
}
return sb.makeStringAndClear();
}
OUString SAL_CALL
TextToPronounce_zh::transliterateChar2String( sal_Unicode inChar) throw(RuntimeException)
{
return OUString(getPronounce(inChar));
}
sal_Unicode SAL_CALL
TextToPronounce_zh::transliterateChar2Char( sal_Unicode inChar) throw(RuntimeException, MultipleCharsOutputException)
{
const sal_Unicode* pron=getPronounce(inChar);
if (!pron || !pron[0])
return 0;
if (pron[1])
throw MultipleCharsOutputException();
return *pron;
}
sal_Bool SAL_CALL
TextToPronounce_zh::equals( const OUString & str1, sal_Int32 pos1, sal_Int32 nCount1, sal_Int32 & nMatch1,
const OUString & str2, sal_Int32 pos2, sal_Int32 nCount2, sal_Int32 & nMatch2)
throw (RuntimeException)
{
sal_Int32 realCount;
int i; // loop variable
const sal_Unicode * s1, * s2;
const sal_Unicode *pron1, *pron2;
if (nCount1 + pos1 > str1.getLength())
nCount1 = str1.getLength() - pos1;
if (nCount2 + pos2 > str2.getLength())
nCount2 = str2.getLength() - pos2;
realCount = ((nCount1 > nCount2) ? nCount2 : nCount1);
s1 = str1.getStr() + pos1;
s2 = str2.getStr() + pos2;
for (i = 0; i < realCount; i++) {
pron1=getPronounce(*s1++);
pron2=getPronounce(*s2++);
if (pron1 != pron2) {
nMatch1 = nMatch2 = i;
return sal_False;
}
}
nMatch1 = nMatch2 = realCount;
return (nCount1 == nCount2);
}
#ifdef DISABLE_DYNLOADING
extern "C" {
sal_uInt16** get_zh_zhuyin();
sal_uInt16** get_zh_pinyin();
}
#endif
TextToPinyin_zh_CN::TextToPinyin_zh_CN() :
#ifndef DISABLE_DYNLOADING
TextToPronounce_zh("get_zh_pinyin")
#else
TextToPronounce_zh(get_zh_pinyin)
#endif
{
transliterationName = "ChineseCharacterToPinyin";
implementationName = "com.sun.star.i18n.Transliteration.TextToPinyin_zh_CN";
}
TextToChuyin_zh_TW::TextToChuyin_zh_TW() :
#ifndef DISABLE_DYNLOADING
TextToPronounce_zh("get_zh_zhuyin")
#else
TextToPronounce_zh(get_zh_zhuyin)
#endif
{
transliterationName = "ChineseCharacterToChuyin";
implementationName = "com.sun.star.i18n.Transliteration.TextToChuyin_zh_TW";
}
#ifndef DISABLE_DYNLOADING
extern "C" { static void SAL_CALL thisModule() {} }
TextToPronounce_zh::TextToPronounce_zh(const sal_Char* func_name)
{
#ifdef SAL_DLLPREFIX
OUString lib(SAL_DLLPREFIX"index_data" SAL_DLLEXTENSION);
#else
OUString lib("index_data" SAL_DLLEXTENSION);
#endif
hModule = osl_loadModuleRelative(
&thisModule, lib.pData, SAL_LOADMODULE_DEFAULT );
idx=NULL;
if (hModule) {
sal_uInt16** (*function)() = (sal_uInt16** (*)()) osl_getFunctionSymbol(hModule, OUString::createFromAscii(func_name).pData);
if (function)
idx=function();
}
}
#else
TextToPronounce_zh::TextToPronounce_zh(sal_uInt16 ** (*function)())
{
idx = function();
}
#endif
TextToPronounce_zh::~TextToPronounce_zh()
{
#ifndef DISABLE_DYNLOADING
if (hModule) osl_unloadModule(hModule);
#endif
}
} } } }
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */