1 /*
2  * Copyright (c) 2021-2021 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #include "avbuffer_queue_producer_impl.h"
17 
18 
19 namespace OHOS {
20 namespace Media {
21 
AVBufferQueueProducerImpl(std::shared_ptr<AVBufferQueueImpl> & bufferQueue)22 AVBufferQueueProducerImpl::AVBufferQueueProducerImpl(std::shared_ptr<AVBufferQueueImpl>& bufferQueue)
23     : AVBufferQueueProducerStub(), bufferQueue_(bufferQueue) {
24 }
25 
GetQueueSize()26 uint32_t AVBufferQueueProducerImpl::GetQueueSize()
27 {
28     return bufferQueue_->GetQueueSize();
29 }
30 
SetQueueSize(uint32_t size)31 Status AVBufferQueueProducerImpl::SetQueueSize(uint32_t size)
32 {
33     return bufferQueue_->SetQueueSize(size);
34 }
35 
RequestBuffer(std::shared_ptr<AVBuffer> & buffer,const AVBufferConfig & config,int32_t timeoutMs)36 Status AVBufferQueueProducerImpl::RequestBuffer(std::shared_ptr<AVBuffer>& buffer,
37                                                 const AVBufferConfig& config, int32_t timeoutMs)
38 {
39     return bufferQueue_->RequestBuffer(buffer, config, timeoutMs);
40 }
41 
PushBuffer(uint64_t uniqueId,bool available)42 Status AVBufferQueueProducerImpl::PushBuffer(uint64_t uniqueId, bool available)
43 {
44     return bufferQueue_->PushBuffer(uniqueId, available);
45 }
46 
PushBuffer(const std::shared_ptr<AVBuffer> & buffer,bool available)47 Status AVBufferQueueProducerImpl::PushBuffer(const std::shared_ptr<AVBuffer>& buffer, bool available)
48 {
49     return bufferQueue_->PushBuffer(buffer, available);
50 }
51 
ReturnBuffer(uint64_t uniqueId,bool available)52 Status AVBufferQueueProducerImpl::ReturnBuffer(uint64_t uniqueId, bool available)
53 {
54     return bufferQueue_->ReturnBuffer(uniqueId, available);
55 }
56 
ReturnBuffer(const std::shared_ptr<AVBuffer> & buffer,bool available)57 Status AVBufferQueueProducerImpl::ReturnBuffer(const std::shared_ptr<AVBuffer>& buffer, bool available)
58 {
59     return bufferQueue_->ReturnBuffer(buffer, available);
60 }
61 
AttachBuffer(std::shared_ptr<AVBuffer> & buffer,bool isFilled)62 Status AVBufferQueueProducerImpl::AttachBuffer(std::shared_ptr<AVBuffer>& buffer, bool isFilled)
63 {
64     return bufferQueue_->AttachBuffer(buffer, isFilled);
65 }
66 
DetachBuffer(uint64_t uniqueId)67 Status AVBufferQueueProducerImpl::DetachBuffer(uint64_t uniqueId)
68 {
69     return bufferQueue_->DetachBuffer(uniqueId);
70 }
71 
DetachBuffer(const std::shared_ptr<AVBuffer> & buffer)72 Status AVBufferQueueProducerImpl::DetachBuffer(const std::shared_ptr<AVBuffer>& buffer)
73 {
74     return bufferQueue_->DetachBuffer(buffer);
75 }
76 
SetBufferFilledListener(sptr<IBrokerListener> & listener)77 Status AVBufferQueueProducerImpl::SetBufferFilledListener(sptr<IBrokerListener>& listener)
78 {
79     return bufferQueue_->SetBrokerListener(listener);
80 }
81 
RemoveBufferFilledListener(sptr<IBrokerListener> & listener)82 Status AVBufferQueueProducerImpl::RemoveBufferFilledListener(sptr<IBrokerListener>& listener)
83 {
84     return bufferQueue_->RemoveBrokerListener(listener);
85 }
86 
Clear()87 Status AVBufferQueueProducerImpl::Clear()
88 {
89     return bufferQueue_->Clear();
90 }
91 
92 
SetBufferAvailableListener(sptr<IProducerListener> & listener)93 Status AVBufferQueueProducerImpl::SetBufferAvailableListener(sptr<IProducerListener>& listener)
94 {
95     return bufferQueue_->SetProducerListener(listener);
96 }
97 
98 } // namespace Media
99 } // namespace OHOS