summaryrefslogtreecommitdiffstats
path: root/src/libs/engine/Patch.cpp
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2007-04-08 19:33:14 +0000
committerDavid Robillard <d@drobilla.net>2007-04-08 19:33:14 +0000
commitc34d7b6e9354529b6e83c136857e798c63b256fe (patch)
tree5ff63c162597f026f81c82e22a77e02b7da10eea /src/libs/engine/Patch.cpp
parent40e4cf5d669a654728881a00a3659fc3bca0e546 (diff)
downloadingen-c34d7b6e9354529b6e83c136857e798c63b256fe.tar.gz
ingen-c34d7b6e9354529b6e83c136857e798c63b256fe.tar.bz2
ingen-c34d7b6e9354529b6e83c136857e798c63b256fe.zip
Fixed audio output.
git-svn-id: http://svn.drobilla.net/lad/ingen@425 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/libs/engine/Patch.cpp')
-rw-r--r--src/libs/engine/Patch.cpp17
1 files changed, 10 insertions, 7 deletions
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<Port*>::iterator i = _input_ports.begin(); i != _input_ports.end(); ++i)
- (*i)->process(nframes, start, end);
+ // This breaks MIDI input, somehow (?)
+ //for (Raul::List<Port*>::iterator i = _input_ports.begin(); i != _input_ports.end(); ++i)
+ // (*i)->pre_process(nframes, start, end);
+ for (Raul::List<Port*>::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<Port*>::iterator i = _input_ports.begin(); i != _input_ports.end(); ++i)
+ (*i)->post_process(nframes, start, end);
for (Raul::List<Port*>::iterator i = _output_ports.begin(); i != _output_ports.end(); ++i)
- (*i)->process(nframes, start, end);
+ (*i)->post_process(nframes, start, end);
}