diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
commit | 26a029d407be480d791972afb5975cf62c9360a6 (patch) | |
tree | f435a8308119effd964b339f76abb83a57c29483 /intl/icu/source/i18n/unumsys.cpp | |
parent | Initial commit. (diff) | |
download | firefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz firefox-26a029d407be480d791972afb5975cf62c9360a6.zip |
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'intl/icu/source/i18n/unumsys.cpp')
-rw-r--r-- | intl/icu/source/i18n/unumsys.cpp | 88 |
1 files changed, 88 insertions, 0 deletions
diff --git a/intl/icu/source/i18n/unumsys.cpp b/intl/icu/source/i18n/unumsys.cpp new file mode 100644 index 0000000000..9a9fa12e2f --- /dev/null +++ b/intl/icu/source/i18n/unumsys.cpp @@ -0,0 +1,88 @@ +// © 2016 and later: Unicode, Inc. and others. +// License & terms of use: http://www.unicode.org/copyright.html +/* +***************************************************************************************** +* Copyright (C) 2013, International Business Machines Corporation and others. +* All Rights Reserved. +***************************************************************************************** +*/ + +#include "unicode/utypes.h" + +#if !UCONFIG_NO_FORMATTING + +#include "unicode/unumsys.h" +#include "unicode/numsys.h" +#include "unicode/uenum.h" + +U_NAMESPACE_USE + + +U_CAPI UNumberingSystem* U_EXPORT2 +unumsys_open(const char *locale, UErrorCode *status) +{ + // createInstance returns immediately if status indicates error + return (UNumberingSystem*)NumberingSystem::createInstance(Locale(locale), *status); +} + + +U_CAPI UNumberingSystem* U_EXPORT2 +unumsys_openByName(const char *name, UErrorCode *status) +{ + // createInstanceByName does NOT return immediately if status indicates error + if (U_FAILURE(*status)) { + return nullptr; + } + return (UNumberingSystem*)NumberingSystem::createInstanceByName(name, *status); +} + + +U_CAPI void U_EXPORT2 +unumsys_close(UNumberingSystem *unumsys) +{ + delete ((NumberingSystem*)unumsys); +} + + +U_CAPI UEnumeration* U_EXPORT2 +unumsys_openAvailableNames(UErrorCode *status) +{ + // getAvailableNames returns immediately if status indicates error + return uenum_openFromStringEnumeration(NumberingSystem::getAvailableNames(*status), status); +} + + +U_CAPI const char * U_EXPORT2 +unumsys_getName(const UNumberingSystem *unumsys) +{ + return ((NumberingSystem*)unumsys)->getName(); +} + + +U_CAPI int32_t U_EXPORT2 +unumsys_getRadix(const UNumberingSystem *unumsys) +{ + return ((NumberingSystem*)unumsys)->getRadix(); +} + + +U_CAPI UBool U_EXPORT2 +unumsys_isAlgorithmic(const UNumberingSystem *unumsys) +{ + return ((NumberingSystem*)unumsys)->isAlgorithmic(); +} + +U_CAPI int32_t U_EXPORT2 +unumsys_getDescription(const UNumberingSystem *unumsys, char16_t *result, + int32_t resultLength, UErrorCode *status) +{ + if (U_FAILURE(*status)) { + return -1; + } + // implement + UnicodeString descrip = ((NumberingSystem*)unumsys)->getDescription(); + return descrip.extract(result, resultLength, *status); +} + + +#endif /* #if !UCONFIG_NO_FORMATTING */ |