diff options
author | David Robillard <d@drobilla.net> | 2009-05-28 15:57:14 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2009-05-28 15:57:14 +0000 |
commit | ee3bba21b4f2ea2e0e03f93bc9eded6681b9b482 (patch) | |
tree | 185987a38a9737a72840d41c5d5bb525f3d49aea /src/engine | |
parent | eae3b1c1e100fc1b705a2d664cffae4aa5802568 (diff) | |
download | ingen-ee3bba21b4f2ea2e0e03f93bc9eded6681b9b482.tar.gz ingen-ee3bba21b4f2ea2e0e03f93bc9eded6681b9b482.tar.bz2 ingen-ee3bba21b4f2ea2e0e03f93bc9eded6681b9b482.zip |
Create objects via SetMetadataEvent.
Fix subpatch creation.
git-svn-id: http://svn.drobilla.net/lad/trunk/ingen@2025 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/engine')
-rw-r--r-- | src/engine/QueuedEngineInterface.cpp | 24 | ||||
-rw-r--r-- | src/engine/QueuedEvent.hpp | 12 | ||||
-rw-r--r-- | src/engine/events/SetMetadataEvent.cpp | 94 | ||||
-rw-r--r-- | src/engine/events/SetMetadataEvent.hpp | 2 |
4 files changed, 84 insertions, 48 deletions
diff --git a/src/engine/QueuedEngineInterface.cpp b/src/engine/QueuedEngineInterface.cpp index 7c989723..30cc1072 100644 --- a/src/engine/QueuedEngineInterface.cpp +++ b/src/engine/QueuedEngineInterface.cpp @@ -166,27 +166,7 @@ QueuedEngineInterface::put(const URI& uri, cerr << "\t" << i->first << " = " << i->second << " :: " << i->second.type() << endl; cerr << "}" << endl; - bool is_patch = false, is_node = false, is_port = false, is_output = false; - DataType data_type(DataType::UNKNOWN); - ResourceImpl::type(properties, is_patch, is_node, is_port, is_output, data_type); - - // PutEvent - - if (is_patch) { - uint32_t poly = 1; - iterator p = properties.find("ingen:polyphony"); - if (p != properties.end() && p->second.is_valid() && p->second.type() == Atom::INT) - poly = p->second.get_int32(); - push_queued(new CreatePatchEvent( - _engine, _responder, now(), path, poly, properties)); - } else if (is_node) { - const iterator p = properties.find("rdf:instanceOf"); - push_queued(new CreateNodeEvent( - _engine, _responder, now(), path, p->second.get_uri(), true, properties)); - } else if (is_port) { - push_queued(new CreatePortEvent( - _engine, _responder, now(), path, data_type.uri(), is_output, this, properties)); - } + push_queued(new SetMetadataEvent(_engine, _responder, now(), this, meta, path, properties)); } @@ -271,7 +251,7 @@ QueuedEngineInterface::set_property(const URI& uri, Path path = meta ? (string("/") + path.chop_start("/")) : uri.str(); Resource::Properties properties; properties.insert(make_pair(predicate, value)); - push_queued(new SetMetadataEvent(_engine, _responder, now(), meta, path, properties)); + push_queued(new SetMetadataEvent(_engine, _responder, now(), this, meta, path, properties)); } // Requests // diff --git a/src/engine/QueuedEvent.hpp b/src/engine/QueuedEvent.hpp index 40ba9c22..6bc6a898 100644 --- a/src/engine/QueuedEvent.hpp +++ b/src/engine/QueuedEvent.hpp @@ -59,8 +59,10 @@ protected: FrameTime time, bool blocking = false, QueuedEventSource* source = NULL) - : Event(engine, responder, time) - , _pre_processed(false), _blocking(blocking), _source(source) + : Event(engine, responder, time) + , _pre_processed(false) + , _blocking(blocking) + , _source(source) { if (blocking) assert(_source); @@ -68,8 +70,10 @@ protected: // NULL event base (for internal events only!) QueuedEvent(Engine& engine) - : Event(engine, SharedPtr<Responder>(), 0) - , _pre_processed(false), _blocking(false), _source(NULL) + : Event(engine, SharedPtr<Responder>(), 0) + , _pre_processed(false) + , _blocking(false) + , _source(NULL) {} bool _pre_processed; diff --git a/src/engine/events/SetMetadataEvent.cpp b/src/engine/events/SetMetadataEvent.cpp index e04b9cea..0349ba29 100644 --- a/src/engine/events/SetMetadataEvent.cpp +++ b/src/engine/events/SetMetadataEvent.cpp @@ -18,30 +18,40 @@ #include "SetMetadataEvent.hpp" #include <string> #include <boost/format.hpp> -#include "Responder.hpp" -#include "Engine.hpp" -#include "PortImpl.hpp" +#include "interface/DataType.hpp" #include "ClientBroadcaster.hpp" +#include "Engine.hpp" +#include "EngineStore.hpp" #include "GraphObjectImpl.hpp" #include "PatchImpl.hpp" #include "PluginImpl.hpp" -#include "EngineStore.hpp" +#include "PortImpl.hpp" +#include "Responder.hpp" +#include "CreatePatchEvent.hpp" +#include "CreateNodeEvent.hpp" +#include "CreatePortEvent.hpp" + using namespace std; using namespace Raul; namespace Ingen { +using namespace Shared; +typedef Shared::Resource::Properties Properties; + SetMetadataEvent::SetMetadataEvent( - Engine& engine, - SharedPtr<Responder> responder, - SampleCount timestamp, - bool meta, - const URI& subject, - const Shared::Resource::Properties& properties) - : QueuedEvent(engine, responder, timestamp) + Engine& engine, + SharedPtr<Responder> responder, + SampleCount timestamp, + QueuedEventSource* source, + bool meta, + const URI& subject, + const Properties& properties) + : QueuedEvent(engine, responder, timestamp, false, source) , _error(NO_ERROR) + , _create_event(NULL) , _subject(subject) , _properties(properties) , _object(NULL) @@ -56,22 +66,52 @@ SetMetadataEvent::SetMetadataEvent( void SetMetadataEvent::pre_process() { - if (_subject.scheme() == Path::scheme && Path::is_valid(_subject.str())) - _object = _engine.engine_store()->find_object(Path(_subject.str())); - else - _object = _engine.node_factory()->plugin(_subject); + typedef Properties::const_iterator iterator; + + bool is_graph_object = (_subject.scheme() == Path::scheme && Path::is_valid(_subject.str())); - if (_object == NULL) { + _object = is_graph_object + ? _engine.engine_store()->find_object(Path(_subject.str())) + : _object = _engine.node_factory()->plugin(_subject); + + if (!_object && !is_graph_object) { _error = NOT_FOUND; QueuedEvent::pre_process(); return; } - /*cerr << "SET " << _object->path() << (_property ? " PROP " : " VAR ") - << _key << " :: " << _value.type() << endl;*/ + if (is_graph_object && !_object) { + Path path(_subject.str()); + cerr << "CREATE NEW GRAPH OBJECT" << endl; + bool is_patch = false, is_node = false, is_port = false, is_output = false; + DataType data_type(DataType::UNKNOWN); + ResourceImpl::type(_properties, is_patch, is_node, is_port, is_output, data_type); + if (is_patch) { + uint32_t poly = 1; + iterator p = _properties.find("ingen:polyphony"); + if (p != _properties.end() && p->second.is_valid() && p->second.type() == Atom::INT) + poly = p->second.get_int32(); + _create_event = new CreatePatchEvent(_engine, _responder, _time, + path, poly, _properties); + } else if (is_node) { + const iterator p = _properties.find("rdf:instanceOf"); + _create_event = new CreateNodeEvent(_engine, _responder, _time, + path, p->second.get_uri(), true, _properties); + } else if (is_port) { + _blocking = true; + _create_event = new CreatePortEvent(_engine, _responder, _time, + path, data_type.uri(), is_output, _source, _properties); + } + if (_create_event) + _create_event->pre_process(); + else + _error = BAD_TYPE; + QueuedEvent::pre_process(); + return; + } _types.reserve(_properties.size()); - typedef Shared::Resource::Properties Properties; + for (Properties::iterator p = _properties.begin(); p != _properties.end(); ++p) { const Raul::URI& key = p->first; const Raul::Atom& value = p->second; @@ -109,6 +149,7 @@ SetMetadataEvent::pre_process() _error = BAD_TYPE; } } else { + _object->set_property(key, value); _types.push_back(NONE); } if (_error != NO_ERROR) @@ -128,10 +169,17 @@ SetMetadataEvent::pre_process() void SetMetadataEvent::execute(ProcessContext& context) { - if (_error != NO_ERROR) + if (_error != NO_ERROR) { + QueuedEvent::execute(context); return; + } + + if (_create_event) { + QueuedEvent::execute(context); + _create_event->execute(context); + return; + } - typedef Shared::Resource::Properties Properties; std::vector<SpecialType>::const_iterator t = _types.begin(); for (Properties::iterator p = _properties.begin(); p != _properties.end(); ++p, ++t) { const Raul::Atom& value = p->second; @@ -176,6 +224,8 @@ SetMetadataEvent::post_process() case NO_ERROR: _responder->respond_ok(); _engine.broadcaster()->send_put(_subject, _properties); + if (_create_event) + _create_event->post_process(); break; case NOT_FOUND: _responder->respond_error((boost::format( @@ -184,7 +234,7 @@ SetMetadataEvent::post_process() _responder->respond_error("Internal error"); break; case BAD_TYPE: - _responder->respond_error("Bad type for predicate"); + _responder->respond_error("Bad type"); break; } } diff --git a/src/engine/events/SetMetadataEvent.hpp b/src/engine/events/SetMetadataEvent.hpp index 92b540ff..a3aadfa9 100644 --- a/src/engine/events/SetMetadataEvent.hpp +++ b/src/engine/events/SetMetadataEvent.hpp @@ -64,6 +64,7 @@ public: Engine& engine, SharedPtr<Responder> responder, SampleCount timestamp, + QueuedEventSource* source, bool meta, const Raul::URI& subject, const Shared::Resource::Properties& properties); @@ -82,6 +83,7 @@ private: POLYPHONIC }; + QueuedEvent* _create_event; std::vector<SpecialType> _types; Raul::URI _subject; Shared::Resource::Properties _properties; |