diff options
author | Ben Murdoch <benm@google.com> | 2010-07-29 17:14:53 +0100 |
---|---|---|
committer | Ben Murdoch <benm@google.com> | 2010-08-04 14:29:45 +0100 |
commit | c407dc5cd9bdc5668497f21b26b09d988ab439de (patch) | |
tree | 7eaf8707c0309516bdb042ad976feedaf72b0bb1 /chrome/browser/automation/chrome_frame_automation_provider.cc | |
parent | 0998b1cdac5733f299c12d88bc31ef9c8035b8fa (diff) | |
download | external_chromium-c407dc5cd9bdc5668497f21b26b09d988ab439de.zip external_chromium-c407dc5cd9bdc5668497f21b26b09d988ab439de.tar.gz external_chromium-c407dc5cd9bdc5668497f21b26b09d988ab439de.tar.bz2 |
Merge Chromium src@r53293
Change-Id: Ia79acf8670f385cee48c45b0a75371d8e950af34
Diffstat (limited to 'chrome/browser/automation/chrome_frame_automation_provider.cc')
-rw-r--r-- | chrome/browser/automation/chrome_frame_automation_provider.cc | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/chrome/browser/automation/chrome_frame_automation_provider.cc b/chrome/browser/automation/chrome_frame_automation_provider.cc new file mode 100644 index 0000000..52f8ded --- /dev/null +++ b/chrome/browser/automation/chrome_frame_automation_provider.cc @@ -0,0 +1,79 @@ +// Copyright (c) 2010 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. + +#include "chrome/browser/automation/chrome_frame_automation_provider.h" +#include "chrome/browser/profile.h" +#include "chrome/browser/profile_manager.h" +#include "chrome/test/automation/automation_messages.h" +#include "ipc/ipc_message.h" +#include "ipc/ipc_channel.h" + +ChromeFrameAutomationProvider::ChromeFrameAutomationProvider(Profile* profile) + : AutomationProvider(profile) {} + +void ChromeFrameAutomationProvider::OnMessageReceived( + const IPC::Message& message) { + if (IsValidMessage(message.type())) { + AutomationProvider::OnMessageReceived(message); + } else { + OnUnhandledMessage(message); + } +} + +void ChromeFrameAutomationProvider::OnUnhandledMessage( + const IPC::Message& message) { + NOTREACHED() << __FUNCTION__ + << " Unhandled message type: " + << message.type(); +} + +bool ChromeFrameAutomationProvider::IsValidMessage(uint32 type) { + bool is_valid_message = false; + + switch (type) { + case AutomationMsg_CreateExternalTab::ID: + case AutomationMsg_ConnectExternalTab::ID: +#if defined(OS_WIN) + case AutomationMsg_BrowserMove::ID: + case AutomationMsg_ProcessUnhandledAccelerator::ID: + case AutomationMsg_TabReposition::ID: + case AutomationMsg_ForwardContextMenuCommandToChrome::ID: +#endif // defined(OS_WIN) + case AutomationMsg_NavigateInExternalTab::ID: + case AutomationMsg_NavigateExternalTabAtIndex::ID: + case AutomationMsg_Find::ID: + case AutomationMsg_InstallExtension::ID: + case AutomationMsg_LoadExpandedExtension::ID: + case AutomationMsg_GetEnabledExtensions::ID: + case AutomationMsg_SetEnableExtensionAutomation::ID: + case AutomationMsg_SetInitialFocus::ID: + case AutomationMsg_SetPageFontSize::ID: + case AutomationMsg_SetProxyConfig::ID: + case AutomationMsg_Cut::ID: + case AutomationMsg_Copy::ID: + case AutomationMsg_Paste::ID: + case AutomationMsg_SelectAll::ID: + case AutomationMsg_ReloadAsync::ID: + case AutomationMsg_StopAsync::ID: + case AutomationMsg_PrintAsync::ID: + case AutomationMsg_HandleUnused::ID: + case AutomationMsg_HandleMessageFromExternalHost::ID: + case AutomationMsg_RequestStarted::ID: + case AutomationMsg_RequestData::ID: + case AutomationMsg_RequestEnd::ID: + case AutomationMsg_SaveAsAsync::ID: + case AutomationMsg_RemoveBrowsingData::ID: + case AutomationMsg_OverrideEncoding::ID: + case AutomationMsg_RunUnloadHandlers::ID: { + is_valid_message = true; + break; + } + + default: + break; + } + + return is_valid_message; +} + |