// Copyright (c) 2012 The Chromium Embedded Framework 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 "tests/cefclient/renderer/client_renderer.h" #include #include #include "include/cef_crash_util.h" #include "include/cef_dom.h" #include "include/wrapper/cef_helpers.h" #include "include/wrapper/cef_message_router.h" namespace client { namespace renderer { namespace { // Must match the value in client_handler.cc. const char kFocusedNodeChangedMessage[] = "ClientRenderer.FocusedNodeChanged"; class ClientRenderDelegate : public ClientAppRenderer::Delegate { public: ClientRenderDelegate() : last_node_is_editable_(false) {} void OnRenderThreadCreated(CefRefPtr app, CefRefPtr extra_info) OVERRIDE { if (CefCrashReportingEnabled()) { // Set some crash keys for testing purposes. Keys must be defined in the // "crash_reporter.cfg" file. See cef_crash_util.h for details. CefSetCrashKeyValue("testkey_small1", "value1_small_renderer"); CefSetCrashKeyValue("testkey_small2", "value2_small_renderer"); CefSetCrashKeyValue("testkey_medium1", "value1_medium_renderer"); CefSetCrashKeyValue("testkey_medium2", "value2_medium_renderer"); CefSetCrashKeyValue("testkey_large1", "value1_large_renderer"); CefSetCrashKeyValue("testkey_large2", "value2_large_renderer"); } } void OnWebKitInitialized(CefRefPtr app) OVERRIDE { // Create the renderer-side router for query handling. CefMessageRouterConfig config; message_router_ = CefMessageRouterRendererSide::Create(config); } void OnContextCreated(CefRefPtr app, CefRefPtr browser, CefRefPtr frame, CefRefPtr context) OVERRIDE { message_router_->OnContextCreated(browser, frame, context); } void OnContextReleased(CefRefPtr app, CefRefPtr browser, CefRefPtr frame, CefRefPtr context) OVERRIDE { message_router_->OnContextReleased(browser, frame, context); } void OnFocusedNodeChanged(CefRefPtr app, CefRefPtr browser, CefRefPtr frame, CefRefPtr node) OVERRIDE { bool is_editable = (node.get() && node->IsEditable()); if (is_editable != last_node_is_editable_) { // Notify the browser of the change in focused element type. last_node_is_editable_ = is_editable; CefRefPtr message = CefProcessMessage::Create(kFocusedNodeChangedMessage); message->GetArgumentList()->SetBool(0, is_editable); frame->SendProcessMessage(PID_BROWSER, message); } } bool OnProcessMessageReceived(CefRefPtr app, CefRefPtr browser, CefRefPtr frame, CefProcessId source_process, CefRefPtr message) OVERRIDE { return message_router_->OnProcessMessageReceived(browser, frame, source_process, message); } private: bool last_node_is_editable_; // Handles the renderer side of query routing. CefRefPtr message_router_; DISALLOW_COPY_AND_ASSIGN(ClientRenderDelegate); IMPLEMENT_REFCOUNTING(ClientRenderDelegate); }; } // namespace void CreateDelegates(ClientAppRenderer::DelegateSet& delegates) { delegates.insert(new ClientRenderDelegate); } } // namespace renderer } // namespace client