Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(662)

Unified Diff: source/common/brkeng.cpp

Issue 1621843002: ICU 56 update step 1 (Closed) Base URL: https://chromium.googlesource.com/chromium/deps/icu.git@561
Patch Set: Created 4 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « source/common/Makefile.in ('k') | source/common/brkiter.cpp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: source/common/brkeng.cpp
diff --git a/source/common/brkeng.cpp b/source/common/brkeng.cpp
index 2398fe9c0ca67418d797737da5228c7b53ced701..0a5f47c6f1c1b717f0a8ec1d9ac43ea6e999a96f 100644
--- a/source/common/brkeng.cpp
+++ b/source/common/brkeng.cpp
@@ -1,6 +1,6 @@
/*
************************************************************************************
- * Copyright (C) 2006-2014, International Business Machines Corporation
+ * Copyright (C) 2006-2015, International Business Machines Corporation
* and others. All Rights Reserved.
************************************************************************************
*/
@@ -23,6 +23,7 @@
#include "unicode/bytestrie.h"
#include "charstr.h"
#include "dictionarydata.h"
+#include "mutex.h"
#include "uvector.h"
#include "umutex.h"
#include "uresimp.h"
@@ -138,82 +139,38 @@ static void U_CALLCONV _deleteEngine(void *obj) {
U_CDECL_END
U_NAMESPACE_BEGIN
+static UMutex gBreakEngineMutex = U_MUTEX_INITIALIZER;
+
const LanguageBreakEngine *
ICULanguageBreakFactory::getEngineFor(UChar32 c, int32_t breakType) {
- UBool needsInit;
- int32_t i;
const LanguageBreakEngine *lbe = NULL;
UErrorCode status = U_ZERO_ERROR;
- // TODO: The global mutex should not be used.
- // The global mutex should only be used for short periods.
- // A ICULanguageBreakFactory specific mutex should be used.
- umtx_lock(NULL);
- needsInit = (UBool)(fEngines == NULL);
- if (!needsInit) {
- i = fEngines->size();
+ Mutex m(&gBreakEngineMutex);
+
+ if (fEngines == NULL) {
+ UStack *engines = new UStack(_deleteEngine, NULL, status);
+ if (U_FAILURE(status) || engines == NULL) {
+ // Note: no way to return error code to caller.
+ delete engines;
+ return NULL;
+ }
+ fEngines = engines;
+ } else {
+ int32_t i = fEngines->size();
while (--i >= 0) {
lbe = (const LanguageBreakEngine *)(fEngines->elementAt(i));
if (lbe != NULL && lbe->handles(c, breakType)) {
- break;
+ return lbe;
}
- lbe = NULL;
}
}
- umtx_unlock(NULL);
+ // We didn't find an engine. Create one.
+ lbe = loadEngineFor(c, breakType);
if (lbe != NULL) {
- return lbe;
- }
-
- if (needsInit) {
- UStack *engines = new UStack(_deleteEngine, NULL, status);
- if (U_SUCCESS(status) && engines == NULL) {
- status = U_MEMORY_ALLOCATION_ERROR;
- }
- else if (U_FAILURE(status)) {
- delete engines;
- engines = NULL;
- }
- else {
- umtx_lock(NULL);
- if (fEngines == NULL) {
- fEngines = engines;
- engines = NULL;
- }
- umtx_unlock(NULL);
- delete engines;
- }
- }
-
- if (fEngines == NULL) {
- return NULL;
+ fEngines->push((void *)lbe, status);
}
-
- // We didn't find an engine the first time through, or there was no
- // stack. Create an engine.
- const LanguageBreakEngine *newlbe = loadEngineFor(c, breakType);
-
- // Now get the lock, and see if someone else has created it in the
- // meantime
- umtx_lock(NULL);
- i = fEngines->size();
- while (--i >= 0) {
- lbe = (const LanguageBreakEngine *)(fEngines->elementAt(i));
- if (lbe != NULL && lbe->handles(c, breakType)) {
- break;
- }
- lbe = NULL;
- }
- if (lbe == NULL && newlbe != NULL) {
- fEngines->push((void *)newlbe, status);
- lbe = newlbe;
- newlbe = NULL;
- }
- umtx_unlock(NULL);
-
- delete newlbe;
-
return lbe;
}
« no previous file with comments | « source/common/Makefile.in ('k') | source/common/brkiter.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698