summaryrefslogtreecommitdiffstats
path: root/src/libs/engine/ProcessSlave.hpp
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2007-09-30 21:12:16 +0000
committerDavid Robillard <d@drobilla.net>2007-09-30 21:12:16 +0000
commit399ddfc5b1d4f1f131362d0439821778c6681b23 (patch)
treee8ca2536fa251f474817d0575bc3b4747c494954 /src/libs/engine/ProcessSlave.hpp
parentc40ddfc0eebbcb3333d6cc9e3df7fb62ecb45941 (diff)
downloadingen-399ddfc5b1d4f1f131362d0439821778c6681b23.tar.gz
ingen-399ddfc5b1d4f1f131362d0439821778c6681b23.tar.bz2
ingen-399ddfc5b1d4f1f131362d0439821778c6681b23.zip
Better design for process() signature (pass everything needed in a single object parameter).
Working port "monitoring" (connect an output to a control input, GUI will animate controller). git-svn-id: http://svn.drobilla.net/lad/ingen@788 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/libs/engine/ProcessSlave.hpp')
-rw-r--r--src/libs/engine/ProcessSlave.hpp28
1 files changed, 14 insertions, 14 deletions
diff --git a/src/libs/engine/ProcessSlave.hpp b/src/libs/engine/ProcessSlave.hpp
index c341fe64..87a190a2 100644
--- a/src/libs/engine/ProcessSlave.hpp
+++ b/src/libs/engine/ProcessSlave.hpp
@@ -35,8 +35,12 @@ class CompiledPatch;
class ProcessSlave : protected Raul::Slave {
public:
- ProcessSlave(bool realtime)
- : _id(_next_id++), _index(0), _state(STATE_FINISHED), _compiled_patch(NULL)
+ ProcessSlave(Engine& engine, bool realtime)
+ : _id(_next_id++)
+ , _index(0)
+ , _state(STATE_FINISHED)
+ , _compiled_patch(NULL)
+ , _process_context(engine)
{
std::stringstream ss;
ss << "Process Slave ";
@@ -53,15 +57,12 @@ public:
stop();
}
- inline void whip(CompiledPatch* compiled_patch, size_t start_index,
- SampleCount nframes, FrameTime start, FrameTime end) {
+ inline void whip(CompiledPatch* compiled_patch, uint32_t start_index, ProcessContext& context) {
assert(_state == STATE_FINISHED);
_index = start_index;
_state = STATE_RUNNING;
- _nframes = nframes;
- _start = start;
- _end = end;
_compiled_patch = compiled_patch;
+ _process_context.set_time_slice(context.nframes(), context.start(), context.end());
Raul::Slave::whip();
}
@@ -71,24 +72,23 @@ public:
_state.compare_and_exchange(STATE_RUNNING, STATE_FINISH_SIGNALLED);
}
- size_t id() const { return _id; }
+ inline uint32_t id() const { return _id; }
+ inline const ProcessContext& context() const { return _process_context; }
+ inline ProcessContext& context() { return _process_context; }
private:
void _whipped();
- static size_t _next_id;
+ static uint32_t _next_id;
static const int STATE_RUNNING = 0;
static const int STATE_FINISH_SIGNALLED = 1;
static const int STATE_FINISHED = 2;
- size_t _id;
- size_t _index;
+ uint32_t _id;
+ uint32_t _index;
Raul::AtomicInt _state;
- SampleCount _nframes;
- FrameTime _start;
- FrameTime _end;
CompiledPatch* _compiled_patch;
ProcessContext _process_context;
};