/* -*- 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 . */ #ifndef __com_sun_star_resource_XLocale_idl__ #define __com_sun_star_resource_XLocale_idl__ #include #include #include module com { module sun { module star { module resource { /** offers some operations on com::sun::star::lang::Locale structures. @see Locale */ published interface XLocale: com::sun::star::uno::XInterface { /** creates a locale from language, country, and variant.

NOTE: ISO 639 is not a stable standard; some of the language codes it defines (specifically iw, ji, and in) have changed. This constructor accepts both the old codes (iw, ji, and in) and the new codes (he, yi, and id), but all other API on XLocale will return only the NEW codes.

Note: The Java class Locale returns the old codes.

*/ com::sun::star::lang::Locale create( [in] string aLanguage, [in] string aCountry, [in] string aVariant ); /** the common method of getting the current default locale.

It is used for the presentation (for menus, dialogs, etc.). It is, generally, set once when your applet or application is initialized, then never reset. (If you do reset the default locale, you probably want to reload your GUI, so that the change is reflected in your interface.)

More advanced programs allow users to use different locales for different fields, for example, in a spreadsheet.
Note that the initial setting will match the host system.

*/ com::sun::star::lang::Locale getDefault(); /** sets the default locale for the whole environment.

It is normally set once at the beginning of an application, then never reset. setDefault does not reset the host locale.

*/ void setDefault( [in] com::sun::star::lang::Locale newLocale ); /** @returns a sequence of all locales which are available in the system. */ sequence getAvailableLocales(); /** @returns a sequence of all ISO country codes known to the component. */ sequence getISOCountries(); /** @returns a sequence of all ISO language codes known to the component. */ sequence getISOLanguages(); /** @returns a sequence for language codes which are valid within the given country. */ sequence getLanguagesForCountry( [in] string country ); /** @returns the ISO language code for the specified locale. */ string getISO3Language( [in] com::sun::star::lang::Locale locale ) raises( com::sun::star::resource::MissingResourceException ); /** @returns the ISO country code for the specified locale. */ string getISO3Country( [in] com::sun::star::lang::Locale locale ) raises( com::sun::star::resource::MissingResourceException ); /** @returns language code for display of field to user. If the localized name is not found, returns the ISO code. The desired user language is from the default locale. */ string getDisplayLanguage_Default( [in] com::sun::star::lang::Locale locale ); /** @return language code for display of field to user. If the localized name is not found, returns the ISO codes. @param locale the locale. @param inLocale specifies the desired user language. */ string getDisplayLanguage( [in] com::sun::star::lang::Locale locale, [in] com::sun::star::lang::Locale inLocale ); /** @returns country code for display of field to user. If the localized name is not found, returns the ISO code. The desired user country is from the default locale. */ string getDisplayCountry_Default( [in] com::sun::star::lang::Locale locale ); /** @returns country code for display of field to user. If the localized name is not found, returns the ISO codes. @param locale the locale. @param inLocale specifies the desired user country. */ string getDisplayCountry( [in] com::sun::star::lang::Locale locale, [in] com::sun::star::lang::Locale inLocale ); /** @returns variant code for display of field to user. The desired user variant is from the default locale. */ string getDisplayVariant_Default( [in] com::sun::star::lang::Locale locale ); /** @returns variant code for display of field to user. If the localized name is not found, returns the ISO codes. @param locale the locale. @param inLocale specifies the desired user variant. */ string getDisplayVariant( [in] com::sun::star::lang::Locale locale, [in] com::sun::star::lang::Locale inLocale ); /** @returns a string to display the entire locale to user. If the localized name is not found, uses the ISO codes. The default locale is used for the presentation language. @param locale the locale. */ string getDisplayName_Default( [in] com::sun::star::lang::Locale locale ); /** @returns a string to display the entire locale to user. If the localized name is not found, uses the ISO codes. @param locale the locale. @param inLocale specifies the desired user locale. */ string getDisplayName( [in] com::sun::star::lang::Locale locale, [in] com::sun::star::lang::Locale inLocale ); /** @returns `TRUE` if the com::sun::star::lang::Locale l1 is equal to the other one.

A locale is deemed equal to another locale with identical language, country, and variant, and unequal to all other objects. */ boolean equals( [in] com::sun::star::lang::Locale l1, [in] com::sun::star::lang::Locale l2 ); }; }; }; }; }; #endif /* vim:set shiftwidth=4 softtabstop=4 expandtab: */