diff options
author | Florian Dold <florian.dold@gmail.com> | 2019-08-13 12:29:07 +0200 |
---|---|---|
committer | Florian Dold <florian.dold@gmail.com> | 2019-08-13 12:29:22 +0200 |
commit | da736d8259331a8ef13bf4bbb10bbb8a5c0e5299 (patch) | |
tree | 4d849133b1c9a9c7067e96ff7dd8faa1d927e0bb /deps/node/deps/icu-small/source/i18n/collationroot.cpp | |
parent | da228cf9d71b747f1824e85127039e5afc7effd8 (diff) | |
download | akono-da736d8259331a8ef13bf4bbb10bbb8a5c0e5299.tar.gz akono-da736d8259331a8ef13bf4bbb10bbb8a5c0e5299.tar.bz2 akono-da736d8259331a8ef13bf4bbb10bbb8a5c0e5299.zip |
remove node/v8 from source tree
Diffstat (limited to 'deps/node/deps/icu-small/source/i18n/collationroot.cpp')
-rw-r--r-- | deps/node/deps/icu-small/source/i18n/collationroot.cpp | 104 |
1 files changed, 0 insertions, 104 deletions
diff --git a/deps/node/deps/icu-small/source/i18n/collationroot.cpp b/deps/node/deps/icu-small/source/i18n/collationroot.cpp deleted file mode 100644 index 71753bd6..00000000 --- a/deps/node/deps/icu-small/source/i18n/collationroot.cpp +++ /dev/null @@ -1,104 +0,0 @@ -// © 2016 and later: Unicode, Inc. and others. -// License & terms of use: http://www.unicode.org/copyright.html -/* -******************************************************************************* -* Copyright (C) 2012-2014, International Business Machines -* Corporation and others. All Rights Reserved. -******************************************************************************* -* collationroot.cpp -* -* created on: 2012dec17 -* created by: Markus W. Scherer -*/ - -#include "unicode/utypes.h" - -#if !UCONFIG_NO_COLLATION - -#include "unicode/coll.h" -#include "unicode/udata.h" -#include "collation.h" -#include "collationdata.h" -#include "collationdatareader.h" -#include "collationroot.h" -#include "collationsettings.h" -#include "collationtailoring.h" -#include "normalizer2impl.h" -#include "ucln_in.h" -#include "udatamem.h" -#include "umutex.h" - -U_NAMESPACE_BEGIN - -namespace { - -static const CollationCacheEntry *rootSingleton = NULL; -static UInitOnce initOnce = U_INITONCE_INITIALIZER; - -} // namespace - -U_CDECL_BEGIN - -static UBool U_CALLCONV uprv_collation_root_cleanup() { - SharedObject::clearPtr(rootSingleton); - initOnce.reset(); - return TRUE; -} - -U_CDECL_END - -void U_CALLCONV -CollationRoot::load(UErrorCode &errorCode) { - if(U_FAILURE(errorCode)) { return; } - LocalPointer<CollationTailoring> t(new CollationTailoring(NULL)); - if(t.isNull() || t->isBogus()) { - errorCode = U_MEMORY_ALLOCATION_ERROR; - return; - } - t->memory = udata_openChoice(U_ICUDATA_NAME U_TREE_SEPARATOR_STRING "coll", - "icu", "ucadata", - CollationDataReader::isAcceptable, t->version, &errorCode); - if(U_FAILURE(errorCode)) { return; } - const uint8_t *inBytes = static_cast<const uint8_t *>(udata_getMemory(t->memory)); - CollationDataReader::read(NULL, inBytes, udata_getLength(t->memory), *t, errorCode); - if(U_FAILURE(errorCode)) { return; } - ucln_i18n_registerCleanup(UCLN_I18N_COLLATION_ROOT, uprv_collation_root_cleanup); - CollationCacheEntry *entry = new CollationCacheEntry(Locale::getRoot(), t.getAlias()); - if(entry != NULL) { - t.orphan(); // The rootSingleton took ownership of the tailoring. - entry->addRef(); - rootSingleton = entry; - } -} - -const CollationCacheEntry * -CollationRoot::getRootCacheEntry(UErrorCode &errorCode) { - umtx_initOnce(initOnce, CollationRoot::load, errorCode); - if(U_FAILURE(errorCode)) { return NULL; } - return rootSingleton; -} - -const CollationTailoring * -CollationRoot::getRoot(UErrorCode &errorCode) { - umtx_initOnce(initOnce, CollationRoot::load, errorCode); - if(U_FAILURE(errorCode)) { return NULL; } - return rootSingleton->tailoring; -} - -const CollationData * -CollationRoot::getData(UErrorCode &errorCode) { - const CollationTailoring *root = getRoot(errorCode); - if(U_FAILURE(errorCode)) { return NULL; } - return root->data; -} - -const CollationSettings * -CollationRoot::getSettings(UErrorCode &errorCode) { - const CollationTailoring *root = getRoot(errorCode); - if(U_FAILURE(errorCode)) { return NULL; } - return root->settings; -} - -U_NAMESPACE_END - -#endif // !UCONFIG_NO_COLLATION |