2023-03-06 14:42:04 +01:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
// Copyright The Music Player Daemon Project
|
2009-07-03 01:02:53 +02:00
|
|
|
|
2018-01-01 18:48:34 +01:00
|
|
|
#ifndef MPD_FILTER_HXX
|
|
|
|
#define MPD_FILTER_HXX
|
2009-07-03 01:02:53 +02:00
|
|
|
|
2020-01-18 20:07:09 +01:00
|
|
|
#include "pcm/AudioFormat.hxx"
|
2016-06-22 11:15:49 +02:00
|
|
|
|
2020-03-12 23:20:59 +01:00
|
|
|
#include <cassert>
|
2022-07-04 18:12:12 +02:00
|
|
|
#include <cstddef>
|
|
|
|
#include <span>
|
2013-02-01 18:40:36 +01:00
|
|
|
|
|
|
|
class Filter {
|
2016-06-22 11:15:49 +02:00
|
|
|
protected:
|
|
|
|
AudioFormat out_audio_format;
|
|
|
|
|
2018-01-01 19:23:01 +01:00
|
|
|
explicit Filter(AudioFormat _out_audio_format) noexcept
|
2017-01-06 11:17:55 +01:00
|
|
|
:out_audio_format(_out_audio_format) {
|
|
|
|
assert(out_audio_format.IsValid());
|
|
|
|
}
|
2016-06-22 11:15:49 +02:00
|
|
|
|
2013-02-01 18:40:36 +01:00
|
|
|
public:
|
2021-05-31 07:30:34 +02:00
|
|
|
virtual ~Filter() noexcept = default;
|
2013-02-01 18:40:36 +01:00
|
|
|
|
|
|
|
/**
|
2016-06-22 11:15:49 +02:00
|
|
|
* Returns the #AudioFormat produced by FilterPCM().
|
2013-02-01 18:40:36 +01:00
|
|
|
*/
|
2018-01-01 19:23:01 +01:00
|
|
|
const AudioFormat &GetOutAudioFormat() const noexcept {
|
2016-06-22 11:15:49 +02:00
|
|
|
return out_audio_format;
|
|
|
|
}
|
2013-02-01 18:40:36 +01:00
|
|
|
|
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
|
|
|
}
|
|
|
|
|
2013-02-01 18:40:36 +01:00
|
|
|
/**
|
|
|
|
* Filters a block of PCM data.
|
|
|
|
*
|
2019-08-26 21:01:22 +02:00
|
|
|
* Throws on error.
|
2016-09-04 14:32:09 +02:00
|
|
|
*
|
2013-02-01 18:40:36 +01:00
|
|
|
* @param src the input buffer
|
2024-11-05 11:58:28 +01:00
|
|
|
* @return the output buffer (will be invalidated by deleting
|
|
|
|
* this object or any call to Reset(), FilterPCM() or
|
2024-11-05 12:24:26 +01:00
|
|
|
* Flush()); may be empty if no output is currently available
|
2013-02-01 18:40:36 +01:00
|
|
|
*/
|
2022-07-04 18:12:12 +02:00
|
|
|
virtual std::span<const std::byte> FilterPCM(std::span<const std::byte> src) = 0;
|
2018-01-01 19:22:45 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Flush pending data and return it. This should be called
|
2024-11-05 13:16:28 +01:00
|
|
|
* repeatedly until it returns an empty span.
|
2019-08-26 21:01:58 +02:00
|
|
|
*
|
2024-11-05 12:57:50 +01:00
|
|
|
* After calling this method, this object cannot be used again
|
|
|
|
* (not even Reset() is allowed).
|
|
|
|
*
|
2019-08-26 21:01:58 +02:00
|
|
|
* Throws on error.
|
2024-11-05 12:57:50 +01:00
|
|
|
*
|
|
|
|
* @return pending data (will be invalidated by deleting this
|
|
|
|
* object or by any call to Flush())
|
2018-01-01 19:22:45 +01:00
|
|
|
*/
|
2022-07-04 18:12:12 +02:00
|
|
|
virtual std::span<const std::byte> Flush() {
|
|
|
|
return {};
|
|
|
|
}
|
2013-02-01 18:40:36 +01:00
|
|
|
};
|
2009-07-03 01:02:53 +02:00
|
|
|
|
|
|
|
#endif
|