diff options
author | darin@google.com <darin@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-08-09 08:34:08 +0000 |
---|---|---|
committer | darin@google.com <darin@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-08-09 08:34:08 +0000 |
commit | 2de755222010708f16ea99af9e3dc2cfe41f96cf (patch) | |
tree | 7c2789878bf6fcfe00e8a39e43832479f5b89e11 /chrome/common/ipc_logging.h | |
parent | 0e48e9dc55bd35d15db0476fbcf1c3529a5fa8de (diff) | |
download | chromium_src-2de755222010708f16ea99af9e3dc2cfe41f96cf.zip chromium_src-2de755222010708f16ea99af9e3dc2cfe41f96cf.tar.gz chromium_src-2de755222010708f16ea99af9e3dc2cfe41f96cf.tar.bz2 |
rollback r625 because it made things slower
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@631 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/common/ipc_logging.h')
-rw-r--r-- | chrome/common/ipc_logging.h | 23 |
1 files changed, 11 insertions, 12 deletions
diff --git a/chrome/common/ipc_logging.h b/chrome/common/ipc_logging.h index 9173cd7..7fa2be4 100644 --- a/chrome/common/ipc_logging.h +++ b/chrome/common/ipc_logging.h @@ -27,18 +27,15 @@ // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -#ifndef CHROME_COMMON_IPC_LOGGING_H_ -#define CHROME_COMMON_IPC_LOGGING_H_ +#ifndef CHROME_COMMON_IPC_LOGGING_H__ +#define CHROME_COMMON_IPC_LOGGING_H__ #include "base/lock.h" -#include "base/object_watcher.h" -#include "base/singleton.h" +#include "base/message_loop.h" #include "chrome/common/ipc_message.h" // For IPC_MESSAGE_LOG_ENABLED. #ifdef IPC_MESSAGE_LOG_ENABLED -class MessageLoop; - namespace IPC { class Message; @@ -46,7 +43,8 @@ class Message; // One instance per process. Needs to be created on the main thread (the UI // thread in the browser) but OnPreDispatchMessage/OnPostDispatchMessage // can be called on other threads. -class Logging : public base::ObjectWatcher::Delegate { +class Logging : public base::RefCounted<Logging>, + public MessageLoop::Watcher { public: // Implemented by consumers of log messages. class Consumer { @@ -87,11 +85,10 @@ class Logging : public base::ObjectWatcher::Delegate { static void GetMessageText(uint16 type, std::wstring* name, const Message* message, std::wstring* params); - // ObjectWatcher::Delegate implementation + // MessageLoop::Watcher void OnObjectSignaled(HANDLE object); private: - friend struct DefaultSingletonTraits<IPC::Logging>; Logging(); std::wstring GetEventName(int browser_pid, bool enabled); @@ -100,8 +97,6 @@ class Logging : public base::ObjectWatcher::Delegate { void RegisterWaitForEvent(bool enabled); - base::ObjectWatcher watcher_; - HANDLE logging_event_on_; HANDLE logging_event_off_; bool enabled_; @@ -113,10 +108,14 @@ class Logging : public base::ObjectWatcher::Delegate { MessageLoop* main_thread_; Consumer* consumer_; + + static scoped_refptr<Logging> current_; + + static Lock logger_lock_; }; } // namespace IPC #endif // IPC_MESSAGE_LOG_ENABLED -#endif // CHROME_COMMON_IPC_LOGGING_H_ +#endif // CHROME_COMMON_IPC_LOGGING_H__ |