mpd/src/filter/Filter.hxx

68 lines
1.5 KiB
C++
Raw Normal View History

// SPDX-License-Identifier: GPL-2.0-or-later
// Copyright The Music Player Daemon Project
2018-01-01 18:48:34 +01:00
#ifndef MPD_FILTER_HXX
#define MPD_FILTER_HXX
2020-01-18 20:07:09 +01:00
#include "pcm/AudioFormat.hxx"
#include <cassert>
#include <cstddef>
#include <span>
class Filter {
protected:
AudioFormat out_audio_format;
2018-01-01 19:23:01 +01:00
explicit Filter(AudioFormat _out_audio_format) noexcept
:out_audio_format(_out_audio_format) {
assert(out_audio_format.IsValid());
}
public:
virtual ~Filter() noexcept = default;
/**
* Returns the #AudioFormat produced by FilterPCM().
*/
2018-01-01 19:23:01 +01:00
const AudioFormat &GetOutAudioFormat() const noexcept {
return out_audio_format;
}
2017-01-11 15:24:12 +01:00
/**
* Reset the filter's state, e.g. drop/flush buffers.
*/
2018-01-01 19:23:01 +01:00
virtual void Reset() noexcept {
2017-01-11 15:24:12 +01:00
}
/**
* Filters a block of PCM data.
*
* Throws on error.
*
* @param src the input buffer
* @return the output buffer (will be invalidated by deleting
* this object or any call to Reset(), FilterPCM() or
* Flush()); may be empty if no output is currently available
*/
virtual std::span<const std::byte> FilterPCM(std::span<const std::byte> src) = 0;
/**
* Flush pending data and return it. This should be called
* repeatedly until it returns an empty span.
*
* After calling this method, this object cannot be used again
* (not even Reset() is allowed).
*
* Throws on error.
*
* @return pending data (will be invalidated by deleting this
* object or by any call to Flush())
*/
virtual std::span<const std::byte> Flush() {
return {};
}
};
#endif