2#include <ossia/dataflow/audio_port.hpp>
3#include <ossia/dataflow/graph_node.hpp>
4#include <ossia/dataflow/nodes/media.hpp>
5#include <ossia/dataflow/token_request.hpp>
12 int64_t next_sample_to_read{};
13 raw_stretcher() noexcept = default;
14 raw_stretcher(const raw_stretcher&) noexcept = default;
15 raw_stretcher(raw_stretcher&&) noexcept = default;
16 raw_stretcher& operator=(const raw_stretcher&) noexcept = default;
17 raw_stretcher& operator=(raw_stretcher&&) noexcept = default;
18 raw_stretcher(int64_t pos) noexcept
19 : next_sample_to_read{pos}
23 [[nodiscard]]
static constexpr int64_t start_delay() noexcept {
return 0; }
25 void transport(int64_t date) { next_sample_to_read = date; }
29 run(T& audio_fetcher,
const ossia::token_request& t,
const ossia::exec_state_facade e,
30 double tempo_ratio,
const std::size_t chan,
const int64_t len,
31 const int64_t samples_to_read,
const int64_t samples_to_write,
32 const int64_t samples_offset,
const ossia::mutable_audio_span<double>& ap)
noexcept
36 double** output = (
double**)alloca(
sizeof(
double*) * chan);
37 for(std::size_t i = 0; i < chan; i++)
38 output[i] = ap[i].data() + samples_offset;
40 audio_fetcher.fetch_audio(next_sample_to_read, samples_to_write, output);
41 next_sample_to_read += samples_to_write;
46 double** output = (
double**)alloca(
sizeof(
double*) * chan);
47 for(std::size_t i = 0; i < chan; i++)
48 output[i] = ap[i].data() + samples_offset;
50 audio_fetcher.fetch_audio_backward(next_sample_to_read, samples_to_write, output);
51 next_sample_to_read -= samples_to_write;