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

Side by Side Diff: ppapi/thunk/ppb_media_stream_video_track_thunk.cc

Issue 126823007: [PPAPI] API thunk for video media stream track. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@video_track_thunk
Patch Set: Update Created 6 years, 11 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 2014 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 // From ppb_media_stream_video_track.idl modified Wed Jan 8 13:26:36 2014.
6
7 #include "ppapi/c/pp_completion_callback.h"
8 #include "ppapi/c/pp_errors.h"
9 #include "ppapi/c/ppb_media_stream_video_track.h"
10 #include "ppapi/shared_impl/tracked_callback.h"
11 #include "ppapi/thunk/enter.h"
12 #include "ppapi/thunk/ppb_instance_api.h"
13 #include "ppapi/thunk/ppb_media_stream_video_track_api.h"
14 #include "ppapi/thunk/resource_creation_api.h"
15 #include "ppapi/thunk/thunk.h"
16
17 namespace ppapi {
18 namespace thunk {
19
20 namespace {
21
22 PP_Bool IsMediaStreamVideoTrack(PP_Resource resource) {
23 VLOG(4) << "PPB_MediaStreamVideoTrack::IsMediaStreamVideoTrack()";
24 EnterResource<PPB_MediaStreamVideoTrack_API> enter(resource, false);
25 return PP_FromBool(enter.succeeded());
26 }
27
28 int32_t Configure(PP_Resource video_track, uint32_t max_buffered_frames) {
29 VLOG(4) << "PPB_MediaStreamVideoTrack::Configure()";
30 EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
31 if (enter.failed())
32 return enter.retval();
33 return enter.object()->Configure(max_buffered_frames);
34 }
35
36 struct PP_Var GetId(PP_Resource video_track) {
37 VLOG(4) << "PPB_MediaStreamVideoTrack::GetId()";
38 EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
39 if (enter.failed())
40 return PP_MakeUndefined();
41 return enter.object()->GetId();
42 }
43
44 PP_Bool HasEnded(PP_Resource video_track) {
45 VLOG(4) << "PPB_MediaStreamVideoTrack::HasEnded()";
46 EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
47 if (enter.failed())
48 return PP_FALSE;
yzshen1 2014/01/08 19:01:45 Maybe you should use on-failure tag to override th
Peng 2014/01/08 21:48:37 Done.
49 return enter.object()->HasEnded();
50 }
51
52 int32_t GetFrame(PP_Resource video_track,
53 PP_Resource* frame,
54 struct PP_CompletionCallback callback) {
55 VLOG(4) << "PPB_MediaStreamVideoTrack::GetFrame()";
56 EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track,
57 callback,
58 true);
59 if (enter.failed())
60 return enter.retval();
61 return enter.SetResult(enter.object()->GetFrame(frame, enter.callback()));
62 }
63
64 int32_t RecycleFrame(PP_Resource video_track, PP_Resource frame) {
65 VLOG(4) << "PPB_MediaStreamVideoTrack::RecycleFrame()";
66 EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
67 if (enter.failed())
68 return enter.retval();
69 return enter.object()->RecycleFrame(frame);
70 }
71
72 void Close(PP_Resource video_track) {
73 VLOG(4) << "PPB_MediaStreamVideoTrack::Close()";
74 EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
75 if (enter.failed())
76 return;
77 enter.object()->Close();
78 }
79
80 const PPB_MediaStreamVideoTrack_0_1 g_ppb_mediastreamvideotrack_thunk_0_1 = {
81 &IsMediaStreamVideoTrack,
82 &Configure,
83 &GetId,
84 &HasEnded,
85 &GetFrame,
86 &RecycleFrame,
87 &Close
88 };
89
90 } // namespace
91
92 const PPB_MediaStreamVideoTrack_0_1* GetPPB_MediaStreamVideoTrack_0_1_Thunk() {
93 return &g_ppb_mediastreamvideotrack_thunk_0_1;
94 }
95
96 } // namespace thunk
97 } // namespace ppapi
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698