From f2135439b806e9c375f2e8588be23ea53c69832c Mon Sep 17 00:00:00 2001 From: David Robillard Date: Thu, 28 May 2009 16:41:02 +0000 Subject: Merge request_object and request_plugin. git-svn-id: http://svn.drobilla.net/lad/trunk/ingen@2028 a436a847-0d15-0410-975c-d299462d15a1 --- src/engine/events/RequestObjectEvent.cpp | 22 +++++++++++++++++----- 1 file changed, 17 insertions(+), 5 deletions(-) (limited to 'src/engine/events/RequestObjectEvent.cpp') diff --git a/src/engine/events/RequestObjectEvent.cpp b/src/engine/events/RequestObjectEvent.cpp index dac76f2b..c17e4983 100644 --- a/src/engine/events/RequestObjectEvent.cpp +++ b/src/engine/events/RequestObjectEvent.cpp @@ -32,10 +32,15 @@ using namespace Raul; namespace Ingen { -RequestObjectEvent::RequestObjectEvent(Engine& engine, SharedPtr responder, SampleCount timestamp, const Path& path) +RequestObjectEvent::RequestObjectEvent( + Engine& engine, + SharedPtr responder, + SampleCount timestamp, + const URI& uri) : QueuedEvent(engine, responder, timestamp) - , _path(path) + , _uri(uri) , _object(NULL) + , _plugin(NULL) { } @@ -43,7 +48,10 @@ RequestObjectEvent::RequestObjectEvent(Engine& engine, SharedPtr resp void RequestObjectEvent::pre_process() { - _object = _engine.engine_store()->find_object(_path); + if (Path::is_valid(_uri.str())) + _object = _engine.engine_store()->find_object(Path(_uri.str())); + else + _plugin = _engine.node_factory()->plugin(_uri); QueuedEvent::pre_process(); } @@ -60,10 +68,14 @@ RequestObjectEvent::execute(ProcessContext& context) void RequestObjectEvent::post_process() { - if (!_object) { + if (!_object && !_plugin) { _responder->respond_error("Unable to find object requested."); } else if (_responder->client()) { - ObjectSender::send_object(_responder->client(), _object, true); + _responder->respond_ok(); + if (_object) + _responder->client()->put(_uri, _object->properties()); + else if (_plugin) + _responder->client()->new_plugin(_uri, _plugin->type_uri(), _plugin->symbol()); } else { _responder->respond_error("Unable to find client to send object."); } -- cgit v1.2.1