| Index: chrome/browser/extensions/script_executor_impl.cc
|
| diff --git a/chrome/browser/extensions/script_executor_impl.cc b/chrome/browser/extensions/script_executor_impl.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..3977cb214e165005554e9a4078d173d55bd1deb9
|
| --- /dev/null
|
| +++ b/chrome/browser/extensions/script_executor_impl.cc
|
| @@ -0,0 +1,109 @@
|
| +// Copyright (c) 2012 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/extensions/script_executor_impl.h"
|
| +
|
| +#include "base/callback.h"
|
| +#include "base/logging.h"
|
| +#include "base/pickle.h"
|
| +#include "chrome/common/extensions/extension_messages.h"
|
| +#include "content/public/browser/render_view_host.h"
|
| +#include "content/public/browser/web_contents.h"
|
| +#include "content/public/browser/web_contents_observer.h"
|
| +#include "ipc/ipc_message.h"
|
| +#include "ipc/ipc_message_macros.h"
|
| +
|
| +namespace extensions {
|
| +
|
| +namespace {
|
| +
|
| +const char* kRendererDestroyed = "Renderer destroyed";
|
| +
|
| +class Handler : public content::WebContentsObserver {
|
| + public:
|
| + Handler(content::WebContents* web_contents,
|
| + const ExtensionMsg_ExecuteCode_Params params,
|
| + const ScriptExecutor::ExecuteScriptCallback& callback)
|
| + : request_id_(params.request_id),
|
| + callback_(callback) {
|
| + content::RenderViewHost* rvh = web_contents->GetRenderViewHost();
|
| + rvh->Send(new ExtensionMsg_ExecuteCode(rvh->GetRoutingID(), params));
|
| + Observe(web_contents);
|
| + }
|
| +
|
| + virtual ~Handler() {}
|
| +
|
| + virtual bool OnMessageReceived(const IPC::Message& message) OVERRIDE {
|
| + // Unpack by hand to check the request_id, since there may be multiple
|
| + // requests in flight but only one is for this.
|
| + if (message.type() != ExtensionHostMsg_ExecuteCodeFinished::ID)
|
| + return false;
|
| +
|
| + int message_request_id;
|
| + PickleIterator iter(message);
|
| + if (!message.ReadInt(&iter, &message_request_id)) {
|
| + NOTREACHED() << "malformed extension message";
|
| + return true;
|
| + }
|
| +
|
| + if (message_request_id != request_id_)
|
| + return false;
|
| +
|
| + IPC_BEGIN_MESSAGE_MAP(Handler, message)
|
| + IPC_MESSAGE_HANDLER(ExtensionHostMsg_ExecuteCodeFinished,
|
| + OnExecuteCodeFinished)
|
| + IPC_END_MESSAGE_MAP()
|
| + return true;
|
| + }
|
| +
|
| + virtual void WebContentsDestroyed(content::WebContents* tab) OVERRIDE {
|
| + Observe(NULL);
|
| + callback_.Run(false, kRendererDestroyed);
|
| + delete this;
|
| + }
|
| +
|
| + private:
|
| + void OnExecuteCodeFinished(int request_id,
|
| + bool success,
|
| + const std::string& error) {
|
| + Observe(NULL);
|
| + callback_.Run(success, error);
|
| + delete this;
|
| + }
|
| +
|
| + int request_id_;
|
| + ScriptExecutor::ExecuteScriptCallback callback_;
|
| +};
|
| +
|
| +} // namespace
|
| +
|
| +ScriptExecutorImpl::ScriptExecutorImpl(
|
| + content::WebContents* web_contents)
|
| + : next_request_id_(0),
|
| + web_contents_(web_contents) {}
|
| +
|
| +ScriptExecutorImpl::~ScriptExecutorImpl() {}
|
| +
|
| +void ScriptExecutorImpl::ExecuteScript(
|
| + const std::string& extension_id,
|
| + bool is_javascript,
|
| + const std::string& code,
|
| + bool all_frames,
|
| + UserScript::RunLocation run_at,
|
| + bool in_main_world,
|
| + const ExecuteScriptCallback& callback) {
|
| + ExtensionMsg_ExecuteCode_Params params;
|
| + params.request_id = next_request_id_++;
|
| + params.extension_id = extension_id;
|
| + params.is_javascript = is_javascript;
|
| + params.code = code;
|
| + params.all_frames = all_frames;
|
| + params.run_at = (int) run_at;
|
| + params.in_main_world = in_main_world;
|
| +
|
| + // Handler handles IPCs and deletes itself on completion.
|
| + new Handler(web_contents_, params, callback);
|
| +}
|
| +
|
| +} // namespace extensions
|
|
|