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

Side by Side Diff: ppapi/cpp/dev/audio_output_dev.cc

Issue 2755613002: Support audio output device enumeration and selection in PPAPI (Closed)
Patch Set: Should not include local change to ppapi/generators/idl_outfile.py Created 3 years, 9 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) 2017 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/dev/audio_output_dev.h"
6
7 #include "ppapi/c/pp_bool.h"
8 #include "ppapi/c/pp_errors.h"
9 #include "ppapi/cpp/instance_handle.h"
10 #include "ppapi/cpp/module_impl.h"
11
12 namespace pp {
13
14 namespace {
15
16 template <> const char* interface_name<PPB_AudioOutput_Dev_0_1>() {
17 return PPB_AUDIO_OUTPUT_DEV_INTERFACE_0_1;
18 }
19
20 } // namespace
21
22 AudioOutput_Dev::AudioOutput_Dev() {
23 }
24
25 AudioOutput_Dev::AudioOutput_Dev(const InstanceHandle& instance) {
26 if (has_interface<PPB_AudioOutput_Dev_0_1>()) {
27 PassRefFromConstructor(get_interface<PPB_AudioOutput_Dev_0_1>()->Create(
28 instance.pp_instance()));
29 }
30 }
31
32 AudioOutput_Dev::~AudioOutput_Dev() {
33 }
34
35 // static
36 bool AudioOutput_Dev::IsAvailable() {
37 return has_interface<PPB_AudioOutput_Dev_0_1>();
38 }
39
40 int32_t AudioOutput_Dev::EnumerateDevices(
41 const CompletionCallbackWithOutput<std::vector<DeviceRef_Dev> >& callback) {
42 if (has_interface<PPB_AudioOutput_Dev_0_1>()) {
43 return get_interface<PPB_AudioOutput_Dev_0_1>()->EnumerateDevices(
44 pp_resource(), callback.output(), callback.pp_completion_callback());
45 }
46
47 return callback.MayForce(PP_ERROR_NOINTERFACE);
48 }
49
50 int32_t AudioOutput_Dev::MonitorDeviceChange(
51 PP_MonitorDeviceChangeCallback callback,
52 void* user_data) {
53 if (has_interface<PPB_AudioOutput_Dev_0_1>()) {
54 return get_interface<PPB_AudioOutput_Dev_0_1>()->MonitorDeviceChange(
55 pp_resource(), callback, user_data);
56 }
57
58 return PP_ERROR_NOINTERFACE;
59 }
60
61 int32_t AudioOutput_Dev::Open(const DeviceRef_Dev& device_ref,
62 const AudioConfig& config,
63 PPB_AudioOutput_Callback audio_output_callback,
64 void* user_data,
65 const CompletionCallback& callback) {
66 if (has_interface<PPB_AudioOutput_Dev_0_1>()) {
67 return get_interface<PPB_AudioOutput_Dev_0_1>()->Open(
68 pp_resource(), device_ref.pp_resource(), config.pp_resource(),
69 audio_output_callback, user_data, callback.pp_completion_callback());
70 }
71
72 return callback.MayForce(PP_ERROR_NOINTERFACE);
73 }
74
75 bool AudioOutput_Dev::StartPlayback() {
76 if (has_interface<PPB_AudioOutput_Dev_0_1>()) {
77 return PP_ToBool(get_interface<PPB_AudioOutput_Dev_0_1>()->StartPlayback(
78 pp_resource()));
79 }
80
81 return false;
82 }
83
84 bool AudioOutput_Dev::StopPlayback() {
85 if (has_interface<PPB_AudioOutput_Dev_0_1>()) {
86 return PP_ToBool(get_interface<PPB_AudioOutput_Dev_0_1>()->StopPlayback(
87 pp_resource()));
88 }
89
90 return false;
91 }
92
93 void AudioOutput_Dev::Close() {
94 if (has_interface<PPB_AudioOutput_Dev_0_1>()) {
95 get_interface<PPB_AudioOutput_Dev_0_1>()->Close(pp_resource());
96 }
97 }
98
99 } // namespace pp
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698