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 #ifndef REMOTING_HOST_NATIVE_MESSAGIN_LOG_HANDLER_H_ | 5 #ifndef REMOTING_HOST_NATIVE_MESSAGIN_LOG_HANDLER_H_ |
6 #define REMOTING_HOST_NATIVE_MESSAGIN_LOG_HANDLER_H_ | 6 #define REMOTING_HOST_NATIVE_MESSAGIN_LOG_HANDLER_H_ |
7 | 7 |
8 #include <stddef.h> | 8 #include <stddef.h> |
9 | 9 |
10 #include <memory> | 10 #include <memory> |
11 | 11 |
12 #include "base/callback.h" | 12 #include "base/callback.h" |
13 #include "base/memory/ref_counted.h" | 13 #include "base/memory/ref_counted.h" |
14 #include "base/memory/weak_ptr.h" | 14 #include "base/memory/weak_ptr.h" |
15 #include "base/values.h" | 15 #include "base/values.h" |
16 | 16 |
17 namespace base { | 17 namespace base { |
18 class SingleThreadTaskRunner; | 18 class SingleThreadTaskRunner; |
19 } | 19 } |
20 | 20 |
21 namespace remoting { | 21 namespace remoting { |
22 | 22 |
23 // Helper class for logging::SetLogMessageHandler to deliver log messages to | 23 // Helper class for logging::LogMessageListener to deliver log messages to |
24 // a consistent thread in a thread-safe way and in a format suitable for sending | 24 // a consistent thread in a thread-safe way and in a format suitable for sending |
25 // over a Native Messaging channel. | 25 // over a Native Messaging channel. |
26 class LogMessageHandler { | 26 class LogMessageListener : logging::LogMessageListener { |
27 public: | 27 public: |
28 typedef base::Callback<void(std::unique_ptr<base::Value> message)> Delegate; | 28 typedef base::Callback<void(std::unique_ptr<base::Value> message)> Delegate; |
29 | 29 |
30 explicit LogMessageHandler(const Delegate& delegate); | 30 explicit LogMessageListener(const Delegate& delegate); |
31 ~LogMessageHandler(); | 31 ~LogMessageListener() override; |
32 | 32 |
33 static const char* kDebugMessageTypeName; | 33 static const char* kDebugMessageTypeName; |
34 | 34 |
| 35 // logging::LogMessageListener |
| 36 void OnMessage(int severity, |
| 37 const char* file, |
| 38 int line, |
| 39 size_t message_start, |
| 40 const std::string& str) override; |
| 41 |
35 private: | 42 private: |
36 static bool OnLogMessage( | |
37 int severity, const char* file, int line, | |
38 size_t message_start, const std::string& str); | |
39 void PostLogMessageToCorrectThread( | 43 void PostLogMessageToCorrectThread( |
40 int severity, const char* file, int line, | 44 int severity, const char* file, int line, |
41 size_t message_start, const std::string& str); | 45 size_t message_start, const std::string& str); |
42 void SendLogMessageToClient( | 46 void SendLogMessageToClient( |
43 int severity, const char* file, int line, | 47 int severity, const char* file, int line, |
44 size_t message_start, const std::string& str); | 48 size_t message_start, const std::string& str); |
45 | 49 |
46 Delegate delegate_; | 50 Delegate delegate_; |
47 bool suppress_logging_; | 51 bool suppress_logging_; |
48 scoped_refptr<base::SingleThreadTaskRunner> caller_task_runner_; | 52 scoped_refptr<base::SingleThreadTaskRunner> caller_task_runner_; |
49 logging::LogMessageHandlerFunction previous_log_message_handler_; | 53 base::WeakPtrFactory<LogMessageListener> weak_ptr_factory_; |
50 base::WeakPtrFactory<LogMessageHandler> weak_ptr_factory_; | |
51 }; | 54 }; |
52 | 55 |
53 } // namespace remoting | 56 } // namespace remoting |
54 | 57 |
55 #endif | 58 #endif |
OLD | NEW |