diff options
Diffstat (limited to 'chrome_frame/external_tab.cc')
-rw-r--r-- | chrome_frame/external_tab.cc | 175 |
1 files changed, 167 insertions, 8 deletions
diff --git a/chrome_frame/external_tab.cc b/chrome_frame/external_tab.cc index ecf7927..322f74a 100644 --- a/chrome_frame/external_tab.cc +++ b/chrome_frame/external_tab.cc @@ -12,6 +12,14 @@ DISABLE_RUNNABLE_METHOD_REFCOUNT(ExternalTabProxy); DISABLE_RUNNABLE_METHOD_REFCOUNT(UIDelegate); +namespace { + struct UserDataHolder : public SyncMessageContext { + explicit UserDataHolder(void* p) : data(p) {} + void* data; + }; +} + + ExternalTabProxy::ExternalTabProxy() : state_(NONE), tab_(0), proxy_(NULL), ui_delegate_(NULL) { } @@ -20,10 +28,22 @@ ExternalTabProxy::~ExternalTabProxy() { Destroy(); } +void ExternalTabProxy::Init() { + if (m_hWnd == NULL) { + // Create a window on the UI thread for marshaling messages back and forth + // from the IPC thread. This window cannot be a message only window as the + // external chrome tab window initially is created as a child of this window + CWindowImpl<ExternalTabProxy>::Create(GetDesktopWindow(), NULL, NULL, + WS_CHILDWINDOW | WS_CLIPCHILDREN | WS_CLIPSIBLINGS, WS_EX_TOOLWINDOW); + DCHECK(m_hWnd != NULL); + ui_.SetWindow(m_hWnd, WM_APP + 6); + } +} + void ExternalTabProxy::Destroy() { DCHECK(NULL == done_.get()); done_.reset(new base::WaitableEvent(true, false)); - proxy_factory_->ReleaseProxy(this, tab_params_.profile); + proxy_factory_->ReleaseProxy(this, tab_params_.proxy_params.profile); done_->Wait(); done_.reset(NULL); @@ -35,12 +55,12 @@ void ExternalTabProxy::CreateTab(const CreateTabParams& create_params, UIDelegate* delegate) { DCHECK(ui_delegate_ != NULL); DCHECK_EQ(NONE, state_); + // Create host window if needed. + Init(); ui_delegate_ = delegate; tab_params_ = create_params; state_ = INIT_IN_PROGRESS; - // TODO(stoyan): initialize ProxyParams from CreateTabParams. - ProxyParams p; - proxy_factory_->GetProxy(this, p); + proxy_factory_->GetProxy(this, create_params.proxy_params); } void ExternalTabProxy::Connected(ChromeProxy* proxy) { @@ -48,6 +68,14 @@ void ExternalTabProxy::Connected(ChromeProxy* proxy) { ui_.PostTask(FROM_HERE, NewRunnableMethod(this, &ExternalTabProxy::UiConnected, proxy)); } + +void ExternalTabProxy::UiConnected(ChromeProxy* proxy) { + proxy_ = proxy; + IPC::ExternalTabSettings settings; + // TODO(stoyan): Initialize settings. + proxy->CreateTab(this, settings); +} + void ExternalTabProxy::Disconnected() { // in ipc thread DCHECK(done_.get() != NULL); @@ -59,6 +87,10 @@ void ExternalTabProxy::PeerLost(ChromeProxy* proxy, DisconnectReason reason) { proxy, reason)); } +void ExternalTabProxy::UiPeerLost(ChromeProxy* proxy, DisconnectReason reason) { + // TODO(stoyan): +} + void ExternalTabProxy::Navigate(const std::string& url, const std::string& referrer, bool is_privileged) { // in ui thread @@ -69,23 +101,74 @@ void ExternalTabProxy::Navigate(const std::string& url, return; } + GURL parsed_referrer(referrer); + // If we are still establishing channel, simply replace the params if (state_ == INIT_IN_PROGRESS) { - // TODO(stoyan): replace CreateTabParams with the new ones + tab_params_.url = parsed_url; + tab_params_.referrer = parsed_referrer; } + // Ah! Too late. Wait to get tab handle and then navigate. if (state_ == CREATE_TAB_IN_PROGRESS) { - // ah! too late. wait to get tab handle and then navigate - pending_navigation_.Set(parsed_url, GURL(referrer)); + pending_navigation_.Set(parsed_url, parsed_referrer); } if (state_ == READY) { - proxy_->Tab_Navigate(tab_, parsed_url, GURL(referrer)); + proxy_->Tab_Navigate(tab_, parsed_url, parsed_referrer); } } +void ExternalTabProxy::ConnectToExternalTab(uint64 external_tab_cookie) { + proxy_->ConnectTab(this, m_hWnd, external_tab_cookie); +} + + +void ExternalTabProxy::BlockExternalTab(uint64 cookie) { + proxy_->BlockTab(cookie); +} + +void ExternalTabProxy::SetZoomLevel(PageZoom::Function zoom_level) { + proxy_->Tab_Zoom(tab_, zoom_level); +} + +void ExternalTabProxy::NavigateToIndex(int index) { + CHECK(0); +} + +void ExternalTabProxy::ForwardMessageFromExternalHost( + const std::string& message, const std::string& origin, + const std::string& target) { + proxy_->Tab_PostMessage(tab_, message, origin, target); +} + +void ExternalTabProxy::SetEnableExtensionAutomation( + const std::vector<std::string>& functions_enabled) { + proxy_->Tab_SetEnableExtensionAutomation(tab_, functions_enabled); +} + +void ExternalTabProxy::InstallExtension(const FilePath& crx_path, + void* user_data) { + proxy_->InstallExtension(this, crx_path, new UserDataHolder(user_data)); +} + +void ExternalTabProxy::LoadExpandedExtension(const FilePath& path, + void* user_data) { + proxy_->LoadExtension(this, path, new UserDataHolder(user_data)); +} + +void ExternalTabProxy::GetEnabledExtensions(void* user_data) { + proxy_->GetEnabledExtensions(this, new UserDataHolder(user_data)); +} + +void ExternalTabProxy::ChromeFrameHostMoved() { + proxy_->Tab_OnHostMoved(tab_); +} + +////////////////////////////////////////////////////////////////////////// void ExternalTabProxy::Completed_CreateTab(bool success, HWND chrome_wnd, HWND tab_window, int tab_handle) { // in ipc_thread. + // ui_.PostTask() } void ExternalTabProxy::Completed_ConnectToTab(bool success, @@ -129,3 +212,79 @@ void ExternalTabProxy::TabLoaded(const GURL& url) { ui_.PostTask(FROM_HERE, NewRunnableMethod(ui_delegate_, &UIDelegate::OnLoad, url)); } + +void ExternalTabProxy::MessageToHost(const std::string& message, + const std::string& origin, + const std::string& target) { + ui_.PostTask(FROM_HERE, NewRunnableMethod(ui_delegate_, + &UIDelegate::OnMessageFromChromeFrame, message, origin, target)); +} + +void ExternalTabProxy::HandleAccelerator(const MSG& accel_message) { + ui_.PostTask(FROM_HERE, NewRunnableMethod(ui_delegate_, + &UIDelegate::OnHandleAccelerator, accel_message)); +} + +void ExternalTabProxy::HandleContextMenu(HANDLE menu_handle, int align_flags, + const IPC::ContextMenuParams& params) { + ui_.PostTask(FROM_HERE, NewRunnableMethod(ui_delegate_, + &UIDelegate::OnHandleContextMenu, menu_handle, align_flags, params)); +} + +void ExternalTabProxy::TabbedOut(bool reverse) { + ui_.PostTask(FROM_HERE, NewRunnableMethod(ui_delegate_, + &UIDelegate::OnTabbedOut, reverse)); +} + +void ExternalTabProxy::GoToHistoryOffset(int offset) { + ui_.PostTask(FROM_HERE, NewRunnableMethod(ui_delegate_, + &UIDelegate::OnGoToHistoryOffset, offset)); +} + +void ExternalTabProxy::OpenURL(const GURL& url_to_open, const GURL& referrer, + int open_disposition) { + ui_.PostTask(FROM_HERE, NewRunnableMethod(ui_delegate_, + &UIDelegate::OnOpenURL, url_to_open, referrer, open_disposition)); +} + +void ExternalTabProxy::NavigationFailed(int error_code, const GURL& gurl) { + // TODO(stoyan): +} + +void ExternalTabProxy::DidNavigate(const IPC::NavigationInfo& navigation_info) { + // TODO(stoyan): +} + +void ExternalTabProxy::Network_Start( + int request_id, const IPC::AutomationURLRequest& request_info) { + // TODO(stoyan): url_fetcher_.Start(); +} + +void ExternalTabProxy::Network_Read(int request_id, int bytes_to_read) { + // TODO(stoyan): url_fetcher_.Read(); +} + +void ExternalTabProxy::Network_End(int request_id, const URLRequestStatus& s) { + // TODO(stoyan): +} + +void ExternalTabProxy::Network_DownloadInHost(int request_id) { + // TODO(stoyan): +} + +void ExternalTabProxy::GetCookies(const GURL& url, int cookie_id) { + // TODO(stoyan): +} + +void ExternalTabProxy::SetCookie(const GURL& url, const std::string& cookie) { + // TODO(stoyan): +} + +void ExternalTabProxy::TabClosed() { + // TODO(stoyan): +} + +void ExternalTabProxy::AttachTab( + const IPC::AttachExternalTabParams& attach_params) { + // TODO(stoyan): +} |