1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
|
// Copyright (c) 2010 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.
#include "webkit/glue/plugins/pepper_video_decoder.h"
#include "base/logging.h"
#include "ppapi/c/dev/pp_video_dev.h"
#include "ppapi/c/dev/ppb_video_decoder_dev.h"
#include "ppapi/c/pp_completion_callback.h"
#include "ppapi/c/pp_errors.h"
#include "webkit/glue/plugins/pepper_file_ref.h"
#include "webkit/glue/plugins/pepper_plugin_instance.h"
#include "webkit/glue/plugins/pepper_resource_tracker.h"
namespace pepper {
namespace {
bool GetConfig(PP_Instance instance_id,
PP_VideoCodecId_Dev codec,
PP_VideoConfig_Dev* configs,
int32_t config_size,
int32_t *num_config) {
PluginInstance* instance = ResourceTracker::Get()->GetInstance(instance_id);
*num_config = 0;
if (!instance)
return false;
// Get configs based on codec.
if (configs) {
// Fill in the array of configs.
}
// Update *num_config.
return true;
}
PP_Resource Create(PP_Instance instance_id,
const PP_VideoDecoderConfig_Dev* decoder_config) {
PluginInstance* instance = ResourceTracker::Get()->GetInstance(instance_id);
if (!instance)
return 0;
scoped_refptr<VideoDecoder> decoder(new VideoDecoder(instance));
if (!decoder->Init(*decoder_config))
return 0;
return decoder->GetReference();
}
bool Decode(PP_Resource decoder_id,
PP_VideoCompressedDataBuffer_Dev* input_buffer) {
scoped_refptr<VideoDecoder> decoder(
Resource::GetAs<VideoDecoder>(decoder_id));
if (!decoder)
return false;
decoder->Decode(*input_buffer);
return true;
}
int32_t Flush(PP_Resource decoder_id, PP_CompletionCallback callback) {
scoped_refptr<VideoDecoder> decoder(
Resource::GetAs<VideoDecoder>(decoder_id));
if (!decoder)
return PP_ERROR_BADRESOURCE;
return decoder->Flush(callback);
}
bool ReturnUncompressedDataBuffer(PP_Resource decoder_id,
PP_VideoUncompressedDataBuffer_Dev* buffer) {
scoped_refptr<VideoDecoder> decoder(
Resource::GetAs<VideoDecoder>(decoder_id));
if (!decoder)
return false;
return decoder->ReturnUncompressedDataBuffer(*buffer);
}
const PPB_VideoDecoder_Dev ppb_videodecoder = {
&GetConfig,
&Create,
&Decode,
&Flush,
&ReturnUncompressedDataBuffer
};
} // namespace
VideoDecoder::VideoDecoder(PluginInstance* instance)
: Resource(instance->module()),
instance_(instance) {
}
VideoDecoder::~VideoDecoder() {
}
// static
const PPB_VideoDecoder_Dev* VideoDecoder::GetInterface() {
return &ppb_videodecoder;
}
bool VideoDecoder::Init(const PP_VideoDecoderConfig_Dev& decoder_config) {
if (!instance())
return false;
platform_video_decoder_.reset(
instance()->delegate()->CreateVideoDecoder(decoder_config));
return platform_video_decoder_.get()? true : false;
}
bool VideoDecoder::Decode(PP_VideoCompressedDataBuffer_Dev& input_buffer) {
if (!platform_video_decoder_.get())
return false;
return platform_video_decoder_->Decode(input_buffer);
}
int32_t VideoDecoder::Flush(PP_CompletionCallback& callback) {
if (!platform_video_decoder_.get())
return PP_ERROR_FAILED;
return platform_video_decoder_->Flush(callback);
}
bool VideoDecoder::ReturnUncompressedDataBuffer(
PP_VideoUncompressedDataBuffer_Dev& buffer) {
if (!platform_video_decoder_.get())
return false;
return platform_video_decoder_->ReturnUncompressedDataBuffer(buffer);
}
} // namespace pepper
|