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

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

Issue 2300453002: [Extensions] Begin making Extension port initialization asynchronous (Closed)
Patch Set: lazyboys Created 4 years, 3 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
OLDNEW
(Empty)
1 // Copyright (c) 2012 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/tabs_custom_bindings.h"
6
7 #include <stdint.h>
8
9 #include <string>
10
11 #include "base/bind.h"
12 #include "content/public/renderer/render_frame.h"
13 #include "extensions/common/extension_messages.h"
14 #include "extensions/renderer/script_context.h"
15 #include "v8/include/v8.h"
16
17 namespace extensions {
18
19 TabsCustomBindings::TabsCustomBindings(ScriptContext* context)
20 : ObjectBackedNativeHandler(context) {
21 RouteFunction("OpenChannelToTab", "tabs",
22 base::Bind(&TabsCustomBindings::OpenChannelToTab,
23 base::Unretained(this)));
24 }
25
26 void TabsCustomBindings::OpenChannelToTab(
27 const v8::FunctionCallbackInfo<v8::Value>& args) {
28 content::RenderFrame* render_frame = context()->GetRenderFrame();
29 if (!render_frame)
30 return;
31
32 // tabs_custom_bindings.js unwraps arguments to tabs.connect/sendMessage and
33 // passes them to OpenChannelToTab, in the following order:
34 // - |tab_id| - Positive number that specifies the destination of the channel.
35 // - |frame_id| - Target frame(s) in the tab where onConnect is dispatched:
36 // -1 for all frames, 0 for the main frame, >0 for a child frame.
37 // - |extension_id| - Extension ID of sender and destination.
38 // - |channel_name| - A user-defined channel name.
39 CHECK(args.Length() >= 4 &&
40 args[0]->IsInt32() &&
41 args[1]->IsInt32() &&
42 args[2]->IsString() &&
43 args[3]->IsString());
44
45 ExtensionMsg_TabTargetConnectionInfo info;
46 info.tab_id = args[0]->Int32Value();
47 info.frame_id = args[1]->Int32Value();
48 std::string extension_id = *v8::String::Utf8Value(args[2]);
49 std::string channel_name = *v8::String::Utf8Value(args[3]);
50 int port_id = -1;
51 render_frame->Send(new ExtensionHostMsg_OpenChannelToTab(
52 render_frame->GetRoutingID(), info, extension_id, channel_name,
53 &port_id));
54 args.GetReturnValue().Set(static_cast<int32_t>(port_id));
55 }
56
57 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698