From c34d7b6e9354529b6e83c136857e798c63b256fe Mon Sep 17 00:00:00 2001 From: David Robillard Date: Sun, 8 Apr 2007 19:33:14 +0000 Subject: Fixed audio output. git-svn-id: http://svn.drobilla.net/lad/ingen@425 a436a847-0d15-0410-975c-d299462d15a1 --- src/libs/engine/Patch.cpp | 17 ++++++++++------- 1 file changed, 10 insertions(+), 7 deletions(-) (limited to 'src/libs/engine/Patch.cpp') diff --git a/src/libs/engine/Patch.cpp b/src/libs/engine/Patch.cpp index ad414642..a81b9ee7 100644 --- a/src/libs/engine/Patch.cpp +++ b/src/libs/engine/Patch.cpp @@ -115,23 +115,26 @@ Patch::process(SampleCount nframes, FrameTime start, FrameTime end) if (_process_order == NULL || !_process) return; - // FIXME: This is far too slow, too much checking every cycle + // FIXME: This is far too slow, too much iteration/conditionals every cycle - // Prepare input ports for nodes to consume - for (Raul::List::iterator i = _input_ports.begin(); i != _input_ports.end(); ++i) - (*i)->process(nframes, start, end); + // This breaks MIDI input, somehow (?) + //for (Raul::List::iterator i = _input_ports.begin(); i != _input_ports.end(); ++i) + // (*i)->pre_process(nframes, start, end); + for (Raul::List::iterator i = _output_ports.begin(); i != _output_ports.end(); ++i) + (*i)->pre_process(nframes, start, end); // Run all nodes (consume input ports) for (size_t i=0; i < _process_order->size(); ++i) { // Could be a gap due to a node removal event (see RemoveNodeEvent.cpp) // Yes, this is ugly - if (_process_order->at(i) != NULL) + if (_process_order->at(i)) _process_order->at(i)->process(nframes, start, end); } - // Prepare output ports (for caller to consume) + for (Raul::List::iterator i = _input_ports.begin(); i != _input_ports.end(); ++i) + (*i)->post_process(nframes, start, end); for (Raul::List::iterator i = _output_ports.begin(); i != _output_ports.end(); ++i) - (*i)->process(nframes, start, end); + (*i)->post_process(nframes, start, end); } -- cgit v1.2.1