1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
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 <transliteration_OneToOne.hxx>
22 using namespace com::sun::star::uno
;
24 namespace com
{ namespace sun
{ namespace star
{ namespace i18n
{
26 sal_Int16 SAL_CALL
transliteration_OneToOne::getType() throw(RuntimeException
, std::exception
)
28 // This type is also defined in com/sun/star/util/TransliterationType.hdl
29 return TransliterationType::ONE_TO_ONE
;
33 transliteration_OneToOne::folding( const OUString
& /*inStr*/, sal_Int32
/*startPos*/,
34 sal_Int32
/*nCount*/, Sequence
< sal_Int32
>& /*offset*/) throw(RuntimeException
, std::exception
)
36 throw RuntimeException();
40 transliteration_OneToOne::equals( const OUString
& /*str1*/, sal_Int32
/*pos1*/, sal_Int32
/*nCount1*/,
41 sal_Int32
& /*nMatch1*/, const OUString
& /*str2*/, sal_Int32
/*pos2*/, sal_Int32
/*nCount2*/, sal_Int32
& /*nMatch2*/ )
42 throw(RuntimeException
, std::exception
)
44 throw RuntimeException();
47 Sequence
< OUString
> SAL_CALL
48 transliteration_OneToOne::transliterateRange( const OUString
& /*str1*/, const OUString
& /*str2*/ )
49 throw(RuntimeException
, std::exception
)
51 throw RuntimeException();
55 transliteration_OneToOne::transliterate( const OUString
& inStr
, sal_Int32 startPos
,
56 sal_Int32 nCount
, Sequence
< sal_Int32
>& offset
)
57 throw(RuntimeException
, std::exception
)
59 // Create a string buffer which can hold nCount + 1 characters.
60 // The reference count is 1 now.
61 rtl_uString
* newStr
= rtl_uString_alloc(nCount
);
62 sal_Unicode
* dst
= newStr
->buffer
;
63 const sal_Unicode
* src
= inStr
.getStr() + startPos
;
65 // Allocate nCount length to offset argument.
67 sal_Int32 position
= 0;
69 offset
.realloc( nCount
);
70 p
= offset
.getArray();
75 while (nCount
-- > 0) {
76 sal_Unicode c
= *src
++;
77 *dst
++ = func
? func( c
) : (*table
)[ c
];
81 *dst
= (sal_Unicode
) 0;
83 return OUString(newStr
, SAL_NO_ACQUIRE
); // take ownership
87 transliteration_OneToOne::transliterateChar2Char( sal_Unicode inChar
) throw(RuntimeException
, MultipleCharsOutputException
, std::exception
)
89 return func
? func( inChar
) : (*table
)[ inChar
];
94 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */