]> granicus.if.org Git - clang/commitdiff
Change libclang initialization to use std::call_once instead of
authorZachary Turner <zturner@google.com>
Tue, 17 Jun 2014 19:57:15 +0000 (19:57 +0000)
committerZachary Turner <zturner@google.com>
Tue, 17 Jun 2014 19:57:15 +0000 (19:57 +0000)
hand rolled once-initialization, and rename the mutex to be more
descriptive of its actual purpose.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@211121 91177308-0d34-0410-b5e6-96231b3b80d8

tools/libclang/CIndex.cpp

index 962e3a340668a906e9bd6af7087031f95efb7c0f..cbe7cf53463faff3565e38ac5e47590e0ba101d7 100644 (file)
@@ -51,6 +51,7 @@
 #include "llvm/Support/Threading.h"
 #include "llvm/Support/Timer.h"
 #include "llvm/Support/raw_ostream.h"
+#include <mutex>
 
 #ifdef __APPLE__
 #include <pthread.h>
@@ -2559,8 +2560,8 @@ buildPieces(unsigned NameFlags, bool IsMemberRefExpr,
 // Misc. API hooks.
 //===----------------------------------------------------------------------===//               
 
-static llvm::sys::Mutex EnableMultithreadingMutex;
-static bool EnabledMultithreading;
+static llvm::sys::Mutex LoggingMutex;
+static std::once_flag LibclangGlobalInitFlag;
 
 static void fatal_error_handler(void *user_data, const std::string& reason,
                                 bool gen_crash_diag) {
@@ -2570,6 +2571,12 @@ static void fatal_error_handler(void *user_data, const std::string& reason,
   ::abort();
 }
 
+static void initializeLibClang() {
+  // Install our error handler, and make sure multi-threading is enabled.
+  llvm::llvm_start_multithreaded();
+  llvm::install_fatal_error_handler(fatal_error_handler, nullptr);
+}
+
 extern "C" {
 CXIndex clang_createIndex(int excludeDeclarationsFromPCH,
                           int displayDiagnostics) {
@@ -2578,15 +2585,7 @@ CXIndex clang_createIndex(int excludeDeclarationsFromPCH,
   if (!getenv("LIBCLANG_DISABLE_CRASH_RECOVERY"))
     llvm::CrashRecoveryContext::Enable();
 
-  // Enable support for multithreading in LLVM.
-  {
-    llvm::sys::ScopedLock L(EnableMultithreadingMutex);
-    if (!EnabledMultithreading) {
-      llvm::install_fatal_error_handler(fatal_error_handler, nullptr);
-      llvm::llvm_start_multithreaded();
-      EnabledMultithreading = true;
-    }
-  }
+  std::call_once(LibclangGlobalInitFlag, initializeLibClang);
 
   CIndexer *CIdxr = new CIndexer();
   if (excludeDeclarationsFromPCH)
@@ -6962,7 +6961,7 @@ Logger &cxindex::Logger::operator<<(const llvm::format_object_base &Fmt) {
 cxindex::Logger::~Logger() {
   LogOS.flush();
 
-  llvm::sys::ScopedLock L(EnableMultithreadingMutex);
+  llvm::sys::ScopedLock L(LoggingMutex);
 
   static llvm::TimeRecord sBeginTR = llvm::TimeRecord::getCurrentTime();