| Index: ppapi/thunk/ppb_media_stream_video_track_thunk.cc
|
| diff --git a/ppapi/thunk/ppb_media_stream_video_track_thunk.cc b/ppapi/thunk/ppb_media_stream_video_track_thunk.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..294e2dbf1fd427f50052f1fd8ae8ee73926ee7ec
|
| --- /dev/null
|
| +++ b/ppapi/thunk/ppb_media_stream_video_track_thunk.cc
|
| @@ -0,0 +1,96 @@
|
| +// Copyright (c) 2012 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +// From ppb_url_loader.idl modified Wed Apr 17 11:16:00 2013.
|
| +
|
| +#include <string.h>
|
| +
|
| +#include "ppapi/c/pp_completion_callback.h"
|
| +#include "ppapi/c/pp_errors.h"
|
| +#include "ppapi/c/ppb_media_stream_video_track.h"
|
| +#include "ppapi/shared_impl/tracked_callback.h"
|
| +#include "ppapi/thunk/enter.h"
|
| +#include "ppapi/thunk/ppb_media_stream_video_track_api.h"
|
| +#include "ppapi/thunk/thunk.h"
|
| +
|
| +namespace ppapi {
|
| +namespace thunk {
|
| +
|
| +namespace {
|
| +
|
| +PP_Bool IsMediaStreamVideoTrack(PP_Resource resource) {
|
| + VLOG(4) << "PPB_MediaStreamVideoTrack::IsVideoFrame()";
|
| + EnterResource<PPB_MediaStreamVideoTrack_API> enter(resource, false);
|
| + return PP_FromBool(enter.succeeded());
|
| +}
|
| +
|
| +int32_t Configure(PP_Resource video_track, uint32_t max_buffered_frames) {
|
| + VLOG(4) << "PPB_MediaStreamVideoTrack::Configure()";
|
| + EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
|
| + if (enter.failed())
|
| + return enter.retval();
|
| + return enter.object()->Configure(max_buffered_frames);
|
| +}
|
| +
|
| +struct PP_Var GetId(PP_Resource video_track) {
|
| + VLOG(4) << "PPB_MediaStreamVideoTrack::GetId()";
|
| + EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
|
| + if (enter.failed())
|
| + return PP_MakeNull();
|
| + return enter.object()->GetId();
|
| +}
|
| +
|
| +PP_Bool HasEnded(PP_Resource video_track) {
|
| + VLOG(4) << "PPB_MediaStreamVideoTrack::HasEnded()";
|
| + EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
|
| + if (enter.failed())
|
| + return PP_TRUE;
|
| + return enter.object()->HasEnded();
|
| +}
|
| +
|
| +int32_t GetFrame(PP_Resource video_track,
|
| + PP_Resource* frame,
|
| + struct PP_CompletionCallback callback) {
|
| + VLOG(4) << "PPB_MediaStreamVideoTrack::GetFrame()";
|
| + EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, callback,
|
| + true);
|
| + if (enter.failed())
|
| + return enter.retval();
|
| + return enter.SetResult(enter.object()->GetFrame(frame, enter.callback()));
|
| +}
|
| +
|
| +int32_t RecycleFrame(PP_Resource video_track, PP_Resource frame) {
|
| + VLOG(4) << "PPB_MediaStreamVideoTrack::RecycleFrame()";
|
| + EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
|
| + if (enter.failed())
|
| + return enter.retval();
|
| + return enter.object()->RecycleFrame(frame);
|
| +}
|
| +
|
| +void Close(PP_Resource video_track) {
|
| + VLOG(4) << "PPB_MediaStreamVideoTrack::Close()";
|
| + EnterResource<PPB_MediaStreamVideoTrack_API> enter(video_track, true);
|
| + if (enter.failed())
|
| + return;
|
| + enter.object()->Close();
|
| +}
|
| +
|
| +const PPB_MediaStreamVideoTrack_0_1 g_ppb_media_stream_video_track_0_1 = {
|
| + &IsMediaStreamVideoTrack,
|
| + &Configure,
|
| + &GetId,
|
| + &HasEnded,
|
| + &GetFrame,
|
| + &RecycleFrame,
|
| + &Close
|
| +};
|
| +
|
| +} // namespace
|
| +
|
| +const PPB_MediaStreamVideoTrack_0_1* GetPPB_MediaStreamVideoTrack_0_1_Thunk() {
|
| + return &g_ppb_media_stream_video_track_0_1;
|
| +}
|
| +
|
| +} // namespace thunk
|
| +} // namespace ppapi
|
|
|