summaryrefslogtreecommitdiffstats
path: root/chrome/browser
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser')
-rw-r--r--chrome/browser/browser.vcproj4
-rw-r--r--chrome/browser/browser_init.h2
-rw-r--r--chrome/browser/browser_main.cc14
-rw-r--r--chrome/browser/process_singleton.cc (renamed from chrome/browser/message_window.cc)18
-rw-r--r--chrome/browser/process_singleton.h (renamed from chrome/browser/message_window.h)30
5 files changed, 35 insertions, 33 deletions
diff --git a/chrome/browser/browser.vcproj b/chrome/browser/browser.vcproj
index d341b5a..7953983 100644
--- a/chrome/browser/browser.vcproj
+++ b/chrome/browser/browser.vcproj
@@ -410,11 +410,11 @@
>
</File>
<File
- RelativePath=".\message_window.cc"
+ RelativePath=".\process_singleton.cc"
>
</File>
<File
- RelativePath=".\message_window.h"
+ RelativePath=".\process_singleton.h"
>
</File>
<File
diff --git a/chrome/browser/browser_init.h b/chrome/browser/browser_init.h
index fb3a5d6..e37ab69 100644
--- a/chrome/browser/browser_init.h
+++ b/chrome/browser/browser_init.h
@@ -90,7 +90,7 @@ class BrowserInit {
// process (via the WM_COPYDATA message). |command_line| holds the command
// line we need to process - either from this process or from some other one
// (if |process_startup| is true and we are being called from
- // MessageWindow::OnCopyData).
+ // ProcessSingleton::OnCopyData).
static bool ProcessCommandLine(const CommandLine& command_line,
const std::wstring& cur_dir,
PrefService* prefs, bool process_startup,
diff --git a/chrome/browser/browser_main.cc b/chrome/browser/browser_main.cc
index d7dd579..e7cd0a1 100644
--- a/chrome/browser/browser_main.cc
+++ b/chrome/browser/browser_main.cc
@@ -68,8 +68,8 @@
#include "chrome/browser/browser_trial.h"
#include "chrome/browser/extensions/extension_protocols.h"
#include "chrome/browser/jankometer.h"
-#include "chrome/browser/message_window.h"
#include "chrome/browser/metrics/user_metrics.h"
+#include "chrome/browser/process_singleton.h"
#include "chrome/browser/net/dns_global.h"
#include "chrome/browser/net/sdch_dictionary_fetcher.h"
#include "chrome/browser/net/url_fixer_upper.h"
@@ -230,7 +230,7 @@ int BrowserMain(const MainFunctionParams& parameters) {
FilePath user_data_dir;
PathService::Get(chrome::DIR_USER_DATA, &user_data_dir);
- MessageWindow message_window(user_data_dir);
+ ProcessSingleton process_singleton(user_data_dir);
bool is_first_run = FirstRun::IsChromeFirstRun() ||
parsed_command_line.HasSwitch(switches::kFirstRun);
@@ -399,10 +399,10 @@ int BrowserMain(const MainFunctionParams& parameters) {
return FirstRun::ImportNow(profile, parsed_command_line);
// When another process is running, use it instead of starting us.
- if (message_window.NotifyOtherProcess())
+ if (process_singleton.NotifyOtherProcess())
return ResultCodes::NORMAL_EXIT;
- message_window.HuntForZombieChromeProcesses();
+ process_singleton.HuntForZombieChromeProcesses();
// Do the tasks if chrome has been upgraded while it was last running.
if (!already_running && DoUpgradeTasks(parsed_command_line)) {
@@ -419,7 +419,7 @@ int BrowserMain(const MainFunctionParams& parameters) {
if (CheckMachineLevelInstall())
return ResultCodes::MACHINE_LEVEL_INSTALL_EXISTS;
- message_window.Create();
+ process_singleton.Create();
// Show the First Run UI if this is the first time Chrome has been run on
// this computer, or we're being compelled to do so by a command line flag.
@@ -429,9 +429,9 @@ int BrowserMain(const MainFunctionParams& parameters) {
if (is_first_run && !first_run_ui_bypass) {
// We need to avoid dispatching new tabs when we are doing the import
// because that will lead to data corruption or a crash. Lock() does that.
- message_window.Lock();
+ process_singleton.Lock();
OpenFirstRunDialog(profile);
- message_window.Unlock();
+ process_singleton.Unlock();
}
// Sets things up so that if we crash from this point on, a dialog will
diff --git a/chrome/browser/message_window.cc b/chrome/browser/process_singleton.cc
index 2174667..61a6d9f 100644
--- a/chrome/browser/message_window.cc
+++ b/chrome/browser/process_singleton.cc
@@ -2,7 +2,7 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#include "chrome/browser/message_window.h"
+#include "chrome/browser/process_singleton.h"
#include "base/base_paths.h"
#include "base/command_line.h"
@@ -34,7 +34,7 @@ BOOL CALLBACK BrowserWindowEnumeration(HWND window, LPARAM param) {
} // namespace
-MessageWindow::MessageWindow(const FilePath& user_data_dir)
+ProcessSingleton::ProcessSingleton(const FilePath& user_data_dir)
: window_(NULL),
locked_(false) {
// Look for a Chrome instance that uses the same profile directory:
@@ -44,12 +44,12 @@ MessageWindow::MessageWindow(const FilePath& user_data_dir)
user_data_dir.ToWStringHack().c_str());
}
-MessageWindow::~MessageWindow() {
+ProcessSingleton::~ProcessSingleton() {
if (window_)
DestroyWindow(window_);
}
-bool MessageWindow::NotifyOtherProcess() {
+bool ProcessSingleton::NotifyOtherProcess() {
if (!remote_window_)
return false;
@@ -127,14 +127,14 @@ bool MessageWindow::NotifyOtherProcess() {
return false;
}
-void MessageWindow::Create() {
+void ProcessSingleton::Create() {
DCHECK(!window_);
DCHECK(!remote_window_);
HINSTANCE hinst = GetModuleHandle(NULL);
WNDCLASSEX wc = {0};
wc.cbSize = sizeof(wc);
- wc.lpfnWndProc = MessageWindow::WndProcStatic;
+ wc.lpfnWndProc = ProcessSingleton::WndProcStatic;
wc.hInstance = hinst;
wc.lpszClassName = chrome::kMessageWindowClass;
RegisterClassEx(&wc);
@@ -151,7 +151,7 @@ void MessageWindow::Create() {
win_util::SetWindowUserData(window_, this);
}
-LRESULT MessageWindow::OnCopyData(HWND hwnd, const COPYDATASTRUCT* cds) {
+LRESULT ProcessSingleton::OnCopyData(HWND hwnd, const COPYDATASTRUCT* cds) {
// Ignore the request if the browser process is already in shutdown path.
if (!g_browser_process || g_browser_process->IsShuttingDown()) {
LOG(WARNING) << "Not handling WM_COPYDATA as browser is shutting down";
@@ -237,7 +237,7 @@ LRESULT MessageWindow::OnCopyData(HWND hwnd, const COPYDATASTRUCT* cds) {
return TRUE;
}
-LRESULT CALLBACK MessageWindow::WndProc(HWND hwnd, UINT message,
+LRESULT CALLBACK ProcessSingleton::WndProc(HWND hwnd, UINT message,
WPARAM wparam, LPARAM lparam) {
switch (message) {
case WM_COPYDATA:
@@ -250,7 +250,7 @@ LRESULT CALLBACK MessageWindow::WndProc(HWND hwnd, UINT message,
return ::DefWindowProc(hwnd, message, wparam, lparam);
}
-void MessageWindow::HuntForZombieChromeProcesses() {
+void ProcessSingleton::HuntForZombieChromeProcesses() {
// Detecting dead renderers is simple:
// - The process is named chrome.exe.
// - The process' parent doesn't exist anymore.
diff --git a/chrome/browser/message_window.h b/chrome/browser/process_singleton.h
index 632c82d..7e38def 100644
--- a/chrome/browser/message_window.h
+++ b/chrome/browser/process_singleton.h
@@ -2,8 +2,8 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#ifndef CHROME_BROWSER_MESSAGE_WINDOW_H_
-#define CHROME_BROWSER_MESSAGE_WINDOW_H_
+#ifndef CHROME_BROWSER_PROCESS_SINGLETON_H_
+#define CHROME_BROWSER_PROCESS_SINGLETON_H_
#include <string>
#include <windows.h>
@@ -11,18 +11,20 @@
#include "base/basictypes.h"
#include "base/file_path.h"
-// MessageWindow -------------------------------------------------------------
+// ProcessSingleton ----------------------------------------------------------
//
-// Class for dealing with the invisible global message window for IPC. This
-// window allows different browser processes to communicate with each other.
-// It is named according to the user data directory, so we can be sure that
-// no more than one copy of the application can be running at once with a
-// given data directory.
+// This class allows different browser processes to communicate with
+// each other. It is named according to the user data directory, so
+// we can be sure that no more than one copy of the application can be
+// running at once with a given data directory.
+//
+// The Windows implementation uses an invisible global message window for
+// IPC.
-class MessageWindow {
+class ProcessSingleton {
public:
- explicit MessageWindow(const FilePath& user_data_dir);
- ~MessageWindow();
+ explicit ProcessSingleton(const FilePath& user_data_dir);
+ ~ProcessSingleton();
// Returns true if another process was found and notified, false if we
// should continue with this process. Roughly based on Mozilla
@@ -61,7 +63,7 @@ class MessageWindow {
UINT message,
WPARAM wparam,
LPARAM lparam) {
- MessageWindow* msg_wnd = reinterpret_cast<MessageWindow*>(
+ ProcessSingleton* msg_wnd = reinterpret_cast<ProcessSingleton*>(
GetWindowLongPtr(hwnd, GWLP_USERDATA));
return msg_wnd->WndProc(hwnd, message, wparam, lparam);
}
@@ -70,7 +72,7 @@ class MessageWindow {
HWND window_; // The HWND_MESSAGE window.
bool locked_;
- DISALLOW_COPY_AND_ASSIGN(MessageWindow);
+ DISALLOW_COPY_AND_ASSIGN(ProcessSingleton);
};
-#endif // #ifndef CHROME_BROWSER_MESSAGE_WINDOW_H_
+#endif // #ifndef CHROME_BROWSER_PROCESS_SINGLETON_H_