| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "remoting/host/native_messaging/log_message_handler.h" | 5 #include "remoting/host/native_messaging/log_message_handler.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/lazy_instance.h" | 8 #include "base/lazy_instance.h" |
| 9 #include "base/strings/string_util.h" | 9 #include "base/strings/string_util.h" |
| 10 #include "base/synchronization/lock.h" | 10 #include "base/synchronization/lock.h" |
| (...skipping 18 matching lines...) Expand all Loading... |
| 29 const Delegate& delegate) | 29 const Delegate& delegate) |
| 30 : delegate_(delegate), | 30 : delegate_(delegate), |
| 31 suppress_logging_(false), | 31 suppress_logging_(false), |
| 32 caller_task_runner_(base::ThreadTaskRunnerHandle::Get()), | 32 caller_task_runner_(base::ThreadTaskRunnerHandle::Get()), |
| 33 weak_ptr_factory_(this) { | 33 weak_ptr_factory_(this) { |
| 34 base::AutoLock lock(g_log_message_handler_lock.Get()); | 34 base::AutoLock lock(g_log_message_handler_lock.Get()); |
| 35 if (g_log_message_handler) { | 35 if (g_log_message_handler) { |
| 36 LOG(FATAL) << "LogMessageHandler is already registered. Only one instance " | 36 LOG(FATAL) << "LogMessageHandler is already registered. Only one instance " |
| 37 << "per process is allowed."; | 37 << "per process is allowed."; |
| 38 } | 38 } |
| 39 previous_log_message_handler_ = logging::GetLogMessageHandler(); | 39 logging::PushLogMessageHandler(&LogMessageHandler::OnLogMessage); |
| 40 logging::SetLogMessageHandler(&LogMessageHandler::OnLogMessage); | |
| 41 g_log_message_handler = this; | 40 g_log_message_handler = this; |
| 42 } | 41 } |
| 43 | 42 |
| 44 LogMessageHandler::~LogMessageHandler() { | 43 LogMessageHandler::~LogMessageHandler() { |
| 45 base::AutoLock lock(g_log_message_handler_lock.Get()); | 44 base::AutoLock lock(g_log_message_handler_lock.Get()); |
| 46 if (logging::GetLogMessageHandler() != &LogMessageHandler::OnLogMessage) { | 45 logging::PopLogMessageHandler(&LogMessageHandler::OnLogMessage); |
| 47 LOG(FATAL) << "LogMessageHandler is not the top-most message handler. " | |
| 48 << "Cannot unregister."; | |
| 49 } | |
| 50 logging::SetLogMessageHandler(previous_log_message_handler_); | |
| 51 g_log_message_handler = nullptr; | 46 g_log_message_handler = nullptr; |
| 52 } | 47 } |
| 53 | 48 |
| 54 // static | 49 // static |
| 55 const char* LogMessageHandler::kDebugMessageTypeName = "_debug_log"; | 50 const char* LogMessageHandler::kDebugMessageTypeName = "_debug_log"; |
| 56 | 51 |
| 57 // static | 52 // static |
| 58 bool LogMessageHandler::OnLogMessage( | 53 bool LogMessageHandler::OnLogMessage( |
| 59 logging::LogSeverity severity, | 54 logging::LogSeverity severity, |
| 60 const char* file, | 55 const char* file, |
| (...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 123 dictionary->SetString("message", message); | 118 dictionary->SetString("message", message); |
| 124 dictionary->SetString("file", file); | 119 dictionary->SetString("file", file); |
| 125 dictionary->SetInteger("line", line); | 120 dictionary->SetInteger("line", line); |
| 126 | 121 |
| 127 delegate_.Run(std::move(dictionary)); | 122 delegate_.Run(std::move(dictionary)); |
| 128 | 123 |
| 129 suppress_logging_ = false; | 124 suppress_logging_ = false; |
| 130 } | 125 } |
| 131 | 126 |
| 132 } // namespace remoting | 127 } // namespace remoting |
| OLD | NEW |