summaryrefslogtreecommitdiffstats
path: root/chrome/common/ipc_logging.h
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/common/ipc_logging.h')
-rw-r--r--chrome/common/ipc_logging.h113
1 files changed, 0 insertions, 113 deletions
diff --git a/chrome/common/ipc_logging.h b/chrome/common/ipc_logging.h
deleted file mode 100644
index cfdcf21..0000000
--- a/chrome/common/ipc_logging.h
+++ /dev/null
@@ -1,113 +0,0 @@
-// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#ifndef CHROME_COMMON_IPC_LOGGING_H_
-#define CHROME_COMMON_IPC_LOGGING_H_
-
-#include "chrome/common/ipc_message.h" // For IPC_MESSAGE_LOG_ENABLED.
-
-#ifdef IPC_MESSAGE_LOG_ENABLED
-
-#include "base/lock.h"
-#include "base/message_loop.h"
-#include "base/singleton.h"
-#include "base/waitable_event_watcher.h"
-#include "chrome/common/ipc_message_utils.h"
-
-class MessageLoop;
-
-namespace IPC {
-
-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::WaitableEventWatcher::Delegate,
- public MessageLoop::DestructionObserver {
- public:
- // Implemented by consumers of log messages.
- class Consumer {
- public:
- virtual void Log(const LogData& data) = 0;
- };
-
- void SetConsumer(Consumer* consumer);
-
- ~Logging();
- static Logging* current();
-
- void Enable();
- void Disable();
- bool Enabled() const { return enabled_; }
-
- // Called by child processes to give the logger object the channel to send
- // logging data to the browser process.
- void SetIPCSender(Message::Sender* sender);
-
- // Called in the browser process when logging data from a child process is
- // received.
- void OnReceivedLoggingMessage(const Message& message);
-
- void OnSendMessage(Message* message, const std::wstring& channel_id);
- void OnPreDispatchMessage(const Message& message);
- void OnPostDispatchMessage(const Message& message,
- const std::wstring& channel_id);
-
- // Returns the name of the logging enabled/disabled events so that the
- // sandbox can add them to to the policy. If true, gets the name of the
- // enabled event, if false, gets the name of the disabled event.
- static std::wstring GetEventName(bool enabled);
-
- // Like the *MsgLog functions declared for each message class, except this
- // calls the correct one based on the message type automatically. Defined in
- // ipc_logging.cc.
- static void GetMessageText(uint16 type, std::wstring* name,
- const Message* message, std::wstring* params);
-
- // WaitableEventWatcher::Delegate implementation
- void OnWaitableEventSignaled(base::WaitableEvent* event);
-
- // MessageLoop::DestructionObserver implementation
- void WillDestroyCurrentMessageLoop();
-
- typedef void (*LogFunction)(uint16 type,
- std::wstring* name,
- const Message* msg,
- std::wstring* params);
-
- static void SetLoggerFunctions(LogFunction *functions);
-
- private:
- friend struct DefaultSingletonTraits<Logging>;
- Logging();
-
- std::wstring GetEventName(int browser_pid, bool enabled);
- void OnSendLogs();
- void Log(const LogData& data);
-
- void RegisterWaitForEvent(bool enabled);
-
- base::WaitableEventWatcher watcher_;
-
- scoped_ptr<base::WaitableEvent> logging_event_on_;
- scoped_ptr<base::WaitableEvent> logging_event_off_;
- bool enabled_;
-
- std::vector<LogData> queued_logs_;
- bool queue_invoke_later_pending_;
-
- Message::Sender* sender_;
- MessageLoop* main_thread_;
-
- Consumer* consumer_;
-
- static LogFunction *log_function_mapping_;
-};
-
-} // namespace IPC
-
-#endif // IPC_MESSAGE_LOG_ENABLED
-
-#endif // CHROME_COMMON_IPC_LOGGING_H_