Version 7.6.3.2-android, tag libreoffice-7.6.3.2-android
[LibreOffice.git] / include / unotools / intlwrapper.hxx
blob0c473cc4293fe11f045e99b6fc2269ce0d9f27e5
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 #ifndef INCLUDED_UNOTOOLS_INTLWRAPPER_HXX
21 #define INCLUDED_UNOTOOLS_INTLWRAPPER_HXX
23 #include <unotools/unotoolsdllapi.h>
24 #include <unotools/collatorwrapper.hxx>
25 #include <com/sun/star/uno/Reference.h>
27 #include <i18nlangtag/languagetag.hxx>
28 #include <memory>
29 #include <optional>
31 namespace com::sun::star::uno { class XComponentContext; }
33 class LocaleDataWrapper;
35 /**
36 A wrapper of I18N wrappers. Using this is more expensive than using some
37 single wrapper classes so use it only if you must pass a single pointer
38 without knowing in advance what is needed, e.g. for
39 SfxPoolItem::GetPresentation(). Remember that this wrapper was only created
40 for convenience to bypass some oddities, if possible don't use it. <p>
42 Implemented are only the const get...() methods of the wrappers, which are
43 loaded on demand, for consistency reasons no change of locale is possible.
44 Only default calendar and default collator are supported. <p>
46 One exception though is the calendar wrapper: to be able to set a value and
47 retrieve calendar values it is not const, so methods using this should
48 reset the calendar to the previous value if it isn't sure where the
49 IntlWrapper did come from. <p>
51 class UNOTOOLS_DLLPUBLIC IntlWrapper
53 private:
54 LanguageTag maLanguageTag;
55 css::uno::Reference< css::uno::XComponentContext > m_xContext;
57 std::unique_ptr<LocaleDataWrapper> pLocaleData;
58 std::optional<CollatorWrapper> moCollator;
59 std::optional<CollatorWrapper> moCaseCollator;
61 void ImplNewLocaleData() const;
62 void ImplNewCollator( bool bCaseSensitive ) const;
64 public:
65 IntlWrapper(LanguageTag aLanguageTag);
66 ~IntlWrapper();
68 const LocaleDataWrapper* getLocaleData() const
70 if ( !pLocaleData )
71 ImplNewLocaleData();
72 return pLocaleData.get();
74 /// case insensitive collator, simple IGNORE_CASE
75 const CollatorWrapper* getCollator() const
77 if ( !moCollator )
78 ImplNewCollator( false );
79 return &*moCollator;
81 /// case sensitive collator
82 const CollatorWrapper* getCaseCollator() const
84 if ( !moCaseCollator )
85 ImplNewCollator( true );
86 return &*moCaseCollator;
90 #endif // INCLUDED_UNOTOOLS_INTLWRAPPER_HXX
92 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */