OLD | NEW |
---|---|
(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 | |
OLD | NEW |