/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* vim:set ts=2 sw=2 sts=2 et cindent: */ /* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #if !defined(AudioTrimmer_h_) # define AudioTrimmer_h_ # include "PlatformDecoderModule.h" # include "mozilla/Mutex.h" namespace mozilla { DDLoggedTypeDeclNameAndBase(AudioTrimmer, MediaDataDecoder); class AudioTrimmer final : public MediaDataDecoder { public: NS_INLINE_DECL_THREADSAFE_REFCOUNTING(AudioTrimmer, final); AudioTrimmer(already_AddRefed aDecoder, const CreateDecoderParams& aParams) : mDecoder(aDecoder) {} RefPtr Init() override; RefPtr Decode(MediaRawData* aSample) override; bool CanDecodeBatch() const override { return mDecoder->CanDecodeBatch(); } RefPtr DecodeBatch( nsTArray>&& aSamples) override; RefPtr Drain() override; RefPtr Flush() override; RefPtr Shutdown() override; nsCString GetDescriptionName() const override; nsCString GetProcessName() const override; nsCString GetCodecName() const override; bool IsHardwareAccelerated(nsACString& aFailureReason) const override; void SetSeekThreshold(const media::TimeUnit& aTime) override; bool SupportDecoderRecycling() const override; ConversionRequired NeedsConversion() const override; private: ~AudioTrimmer() = default; // Apply trimming information on decoded data. aRaw can be null as it's only // used for logging purposes. RefPtr HandleDecodedResult( DecodePromise::ResolveOrRejectValue&& aValue, MediaRawData* aRaw); void PrepareTrimmers(MediaRawData* aRaw); const RefPtr mDecoder; nsCOMPtr mThread; AutoTArray, 2> mTrimmers; }; } // namespace mozilla #endif // AudioTrimmer_h_