1d1766043SAndrew Rist/**************************************************************
2cdf0e10cSrcweir *
3d1766043SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one
4d1766043SAndrew Rist * or more contributor license agreements.  See the NOTICE file
5d1766043SAndrew Rist * distributed with this work for additional information
6d1766043SAndrew Rist * regarding copyright ownership.  The ASF licenses this file
7d1766043SAndrew Rist * to you under the Apache License, Version 2.0 (the
8d1766043SAndrew Rist * "License"); you may not use this file except in compliance
9d1766043SAndrew Rist * with the License.  You may obtain a copy of the License at
10cdf0e10cSrcweir *
11d1766043SAndrew Rist *   http://www.apache.org/licenses/LICENSE-2.0
12d1766043SAndrew Rist *
13d1766043SAndrew Rist * Unless required by applicable law or agreed to in writing,
14d1766043SAndrew Rist * software distributed under the License is distributed on an
15d1766043SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16d1766043SAndrew Rist * KIND, either express or implied.  See the License for the
17d1766043SAndrew Rist * specific language governing permissions and limitations
18d1766043SAndrew Rist * under the License.
19d1766043SAndrew Rist *
20d1766043SAndrew Rist *************************************************************/
21d1766043SAndrew Rist
22d1766043SAndrew Rist
23cdf0e10cSrcweir
24cdf0e10cSrcweir#ifndef __com_sun_star_i18n_XExtendedTextConversion_idl__
25cdf0e10cSrcweir#define __com_sun_star_i18n_XExtendedTextConversion_idl__
26cdf0e10cSrcweir
27cdf0e10cSrcweir#include <com/sun/star/i18n/XTextConversion.idl>
28cdf0e10cSrcweir
29cdf0e10cSrcweir//=============================================================================
30cdf0e10cSrcweir
31cdf0e10cSrcweirmodule com { module sun { module star { module i18n {
32cdf0e10cSrcweir
33cdf0e10cSrcweir//=============================================================================
34cdf0e10cSrcweir
35cdf0e10cSrcweir
36cdf0e10cSrcweir/**
37cdf0e10cSrcweir    This interface provides Text Conversion service.
38cdf0e10cSrcweir
39cdf0e10cSrcweir    <p> It is derived from
40cdf0e10cSrcweir    <type scope="::com::sun::star::i18n">XTextConversion</type> and provides
41cdf0e10cSrcweir    a new conversion function containing position map (offset) between original
42cdf0e10cSrcweir    and conveted string. </p>
43cdf0e10cSrcweir
44*d695a2a0SJürgen Schmidt	 @since OpenOffice 2.0
45cdf0e10cSrcweir */
46cdf0e10cSrcweirpublished interface XExtendedTextConversion : ::com::sun::star::i18n::XTextConversion
47cdf0e10cSrcweir{
48cdf0e10cSrcweir    //-------------------------------------------------------------------------
49cdf0e10cSrcweir    /**
50cdf0e10cSrcweir        The functionality of this method is same as
51cdf0e10cSrcweir        <member scope="::com::sun::star::i18n">XTextConversion::getConversion()</member>,
52cdf0e10cSrcweir        except an additional output parameter rOffset.
53cdf0e10cSrcweir
54cdf0e10cSrcweir        @param rOffset
55cdf0e10cSrcweir            To find the grapheme of input string corresponding to the
56cdf0e10cSrcweir            grapheme of output string, rOffset provides the offset array
57cdf0e10cSrcweir            whose index is the offset of output string, the element
58cdf0e10cSrcweir            containing the position within the input string.
59cdf0e10cSrcweir            When the graphemes of input and output strings are simple
60cdf0e10cSrcweir            one to one mapping, to improve the performance, returned
61cdf0e10cSrcweir            rOffset will be a zero length array.
62cdf0e10cSrcweir     */
63cdf0e10cSrcweir	string getConversionWithOffset(
64cdf0e10cSrcweir            [in] string aText,
65cdf0e10cSrcweir            [in] long nStartPos,
66cdf0e10cSrcweir            [in] long nLength,
67cdf0e10cSrcweir            [in] ::com::sun::star::lang::Locale aLocale,
68cdf0e10cSrcweir            [in] short nTextConversionType,
69cdf0e10cSrcweir            [in] long nTextConversionOptions,
70cdf0e10cSrcweir            [out] sequence <long> rOffset )
71cdf0e10cSrcweir        raises( com::sun::star::lang::IllegalArgumentException,
72cdf0e10cSrcweir                com::sun::star::lang::NoSupportException );
73cdf0e10cSrcweir};
74cdf0e10cSrcweir
75cdf0e10cSrcweir//=============================================================================
76cdf0e10cSrcweir}; }; }; };
77cdf0e10cSrcweir
78cdf0e10cSrcweir#endif
79