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

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 (c) 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.
yzshen1 2014/01/08 17:56:11 Have you tried to auto-generate this file? (I gues
Peng 2014/01/08 18:51:26 Cool! Done.
4
5 #include "ppapi/c/pp_completion_callback.h"
6 #include "ppapi/c/pp_errors.h"
7 #include "ppapi/c/ppb_media_stream_video_track.h"
8 #include "ppapi/shared_impl/tracked_callback.h"
9 #include "ppapi/thunk/enter.h"
10 #include "ppapi/thunk/ppb_media_stream_video_track_api.h"
11 #include "ppapi/thunk/thunk.h"
12
13 namespace ppapi {
14 namespace thunk {
15
16 namespace {
17
18 PP_Bool IsMediaStreamVideoTrack(PP_Resource resource) {
19 VLOG(4) << "PPB_MediaStreamVideoTrack::IsVideoFrame()";
20 EnterResource<PPB_MediaStreamVideoTrack_API> enter(resource, false);
21 return PP_FromBool(enter.succeeded());
22 }
23
24 int32_t Configure(PP_Resource video_track, uint32_t max_buffered_frames) {
25 VLOG(4) << "PPB_MediaStreamVideoTrack::Configure()";
26 EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
27 if (enter.failed())
28 return enter.retval();
29 return enter.object()->Configure(max_buffered_frames);
30 }
31
32 struct PP_Var GetId(PP_Resource video_track) {
33 VLOG(4) << "PPB_MediaStreamVideoTrack::GetId()";
34 EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
35 if (enter.failed())
36 return PP_MakeNull();
yzshen1 2014/01/08 17:56:11 Should it be PP_MakeUndefined()?
Peng 2014/01/08 18:51:26 Done.
37 return enter.object()->GetId();
38 }
39
40 PP_Bool HasEnded(PP_Resource video_track) {
41 VLOG(4) << "PPB_MediaStreamVideoTrack::HasEnded()";
42 EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
43 if (enter.failed())
44 return PP_TRUE;
45 return enter.object()->HasEnded();
46 }
47
48 int32_t GetFrame(PP_Resource video_track,
49 PP_Resource* frame,
50 struct PP_CompletionCallback callback) {
51 VLOG(4) << "PPB_MediaStreamVideoTrack::GetFrame()";
52 EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, callback,
53 true);
54 if (enter.failed())
55 return enter.retval();
56 return enter.SetResult(enter.object()->GetFrame(frame, enter.callback()));
57 }
58
59 int32_t RecycleFrame(PP_Resource video_track, PP_Resource frame) {
60 VLOG(4) << "PPB_MediaStreamVideoTrack::RecycleFrame()";
61 EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
62 if (enter.failed())
63 return enter.retval();
64 return enter.object()->RecycleFrame(frame);
65 }
66
67 void Close(PP_Resource video_track) {
68 VLOG(4) << "PPB_MediaStreamVideoTrack::Close()";
69 EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
70 if (enter.failed())
71 return;
72 enter.object()->Close();
73 }
74
75 const PPB_MediaStreamVideoTrack_0_1 g_ppb_media_stream_video_track_0_1 = {
76 &IsMediaStreamVideoTrack,
77 &Configure,
78 &GetId,
79 &HasEnded,
80 &GetFrame,
81 &RecycleFrame,
82 &Close
83 };
84
85 } // namespace
86
87 const PPB_MediaStreamVideoTrack_0_1* GetPPB_MediaStreamVideoTrack_0_1_Thunk() {
88 return &g_ppb_media_stream_video_track_0_1;
89 }
90
91 } // namespace thunk
92 } // namespace ppapi
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698