Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1123)

Side by Side Diff: chrome/renderer/extensions/render_view_observer_natives.cc

Issue 235943018: Move extensions bindings code out of //chrome (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: nit Created 6 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/renderer/extensions/render_view_observer_natives.h"
6
7 #include "chrome/renderer/extensions/dispatcher.h"
8 #include "content/public/renderer/render_view.h"
9 #include "content/public/renderer/render_view_observer.h"
10 #include "extensions/common/extension_api.h"
11 #include "extensions/renderer/script_context.h"
12 #include "third_party/WebKit/public/web/WebFrame.h"
13 #include "third_party/WebKit/public/web/WebScopedMicrotaskSuppression.h"
14
15 namespace extensions {
16
17 namespace {
18
19 // Deletes itself when done.
20 class LoadWatcher : public content::RenderViewObserver {
21 public:
22 LoadWatcher(ScriptContext* context,
23 content::RenderView* view,
24 v8::Handle<v8::Function> cb)
25 : content::RenderViewObserver(view), context_(context), callback_(cb) {}
26
27 virtual void DidCreateDocumentElement(blink::WebLocalFrame* frame) OVERRIDE {
28 CallbackAndDie(true);
29 }
30
31 virtual void DidFailProvisionalLoad(
32 blink::WebLocalFrame* frame,
33 const blink::WebURLError& error) OVERRIDE {
34 CallbackAndDie(false);
35 }
36
37 private:
38 void CallbackAndDie(bool succeeded) {
39 v8::Isolate* isolate = context_->isolate();
40 v8::HandleScope handle_scope(isolate);
41 v8::Handle<v8::Value> args[] = { v8::Boolean::New(isolate, succeeded) };
42 context_->CallFunction(callback_.NewHandle(isolate), 1, args);
43 delete this;
44 }
45
46 ScriptContext* context_;
47 ScopedPersistent<v8::Function> callback_;
48 DISALLOW_COPY_AND_ASSIGN(LoadWatcher);
49 };
50 } // namespace
51
52
53 RenderViewObserverNatives::RenderViewObserverNatives(Dispatcher* dispatcher,
54 ChromeV8Context* context)
55 : ChromeV8Extension(dispatcher, context) {
56 RouteFunction("OnDocumentElementCreated",
57 base::Bind(&RenderViewObserverNatives::OnDocumentElementCreated,
58 base::Unretained(this)));
59 }
60
61 void RenderViewObserverNatives::OnDocumentElementCreated(
62 const v8::FunctionCallbackInfo<v8::Value>& args) {
63 CHECK(args.Length() == 2);
64 CHECK(args[0]->IsInt32());
65 CHECK(args[1]->IsFunction());
66
67 int view_id = args[0]->Int32Value();
68
69 content::RenderView* view = content::RenderView::FromRoutingID(view_id);
70 if (!view) {
71 LOG(WARNING) << "No render view found to register LoadWatcher.";
72 return;
73 }
74
75 new LoadWatcher(context(), view, args[1].As<v8::Function>());
76
77 args.GetReturnValue().Set(true);
78 }
79
80 } // namespace extensions
OLDNEW
« no previous file with comments | « chrome/renderer/extensions/render_view_observer_natives.h ('k') | chrome/renderer/extensions/send_request_natives.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698