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

Side by Side Diff: ppapi/cpp/vpn_provider.cc

Issue 1726303003: ppapi: PPB_VpnProvider: Define API (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Split patch & responded to reviews Created 4 years, 7 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 2016 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 "ppapi/cpp/vpn_provider.h"
6
7 #include "ppapi/c/ppb_vpn_provider.h"
8 #include "ppapi/cpp/instance.h"
9 #include "ppapi/cpp/instance_handle.h"
10 #include "ppapi/cpp/module.h"
11 #include "ppapi/cpp/module_impl.h"
12 #include "ppapi/cpp/var_array.h"
13
14 namespace pp {
15
16 namespace {
17
18 template <>
19 const char* interface_name<PPB_VpnProvider_0_1>() {
20 return PPB_VPNPROVIDER_INTERFACE_0_1;
21 }
22 } // namespace
23
24 VpnProvider::VpnProvider(const InstanceHandle& instance)
25 : associated_instance_(instance) {
26 if (has_interface<PPB_VpnProvider_0_1>()) {
27 PassRefFromConstructor(get_interface<PPB_VpnProvider_0_1>()->Create(
28 associated_instance_.pp_instance()));
29 }
30 }
31
32 VpnProvider::~VpnProvider() {}
33
34 // static
35 bool VpnProvider::IsAvailable() {
36 return has_interface<PPB_VpnProvider_0_1>();
37 }
38
39 int32_t VpnProvider::Bind(const Var& configuration_id,
40 const Var& configuration_name,
41 const CompletionCallback& callback) {
42 if (has_interface<PPB_VpnProvider_0_1>()) {
43 return get_interface<PPB_VpnProvider_0_1>()->Bind(
44 pp_resource(), configuration_id.pp_var(), configuration_name.pp_var(),
45 callback.pp_completion_callback());
46 }
47 return PP_ERROR_NOINTERFACE;
48 }
49
50 int32_t VpnProvider::GetUnbindEvent(const CompletionCallback& callback) {
51 if (has_interface<PPB_VpnProvider_0_1>()) {
52 return get_interface<PPB_VpnProvider_0_1>()->GetUnbindEvent(
53 pp_resource(), callback.pp_completion_callback());
54 }
55 return PP_ERROR_NOINTERFACE;
56 }
57
58 int32_t VpnProvider::SendPacket(const Var& packet,
59 const CompletionCallback& callback) {
60 if (has_interface<PPB_VpnProvider_0_1>()) {
61 return get_interface<PPB_VpnProvider_0_1>()->SendPacket(
62 pp_resource(), packet.pp_var(), callback.pp_completion_callback());
63 }
64 return PP_ERROR_NOINTERFACE;
65 }
66
67 int32_t VpnProvider::ReceivePacket(
68 const CompletionCallbackWithOutput<Var>& callback) {
69 if (has_interface<PPB_VpnProvider_0_1>()) {
70 return get_interface<PPB_VpnProvider_0_1>()->ReceivePacket(
71 pp_resource(), callback.output(), callback.pp_completion_callback());
72 }
73 return PP_ERROR_NOINTERFACE;
74 }
75
76 } // namespace pp
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698