diff options
author | David Robillard <d@drobilla.net> | 2018-09-23 21:31:46 +0200 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2018-09-23 21:31:46 +0200 |
commit | 017982ff9d5d19d5524ebf010ea74540206c0f94 (patch) | |
tree | eebb678e33e1a54af72e4f2e559b55632dc699a1 | |
parent | 3d117ed9a00c3fdbcb07327d6669aa26c3821720 (diff) | |
download | ingen-017982ff9d5d19d5524ebf010ea74540206c0f94.tar.gz ingen-017982ff9d5d19d5524ebf010ea74540206c0f94.tar.bz2 ingen-017982ff9d5d19d5524ebf010ea74540206c0f94.zip |
Allow context to be passed for serialisation
-rw-r--r-- | ingen/Serialiser.hpp | 4 | ||||
-rw-r--r-- | src/Serialiser.cpp | 7 |
2 files changed, 6 insertions, 5 deletions
diff --git a/ingen/Serialiser.hpp b/ingen/Serialiser.hpp index 824d96b5..16a7a912 100644 --- a/ingen/Serialiser.hpp +++ b/ingen/Serialiser.hpp @@ -20,6 +20,7 @@ #include <stdexcept> #include <string> +#include "ingen/Properties.hpp" #include "ingen/ingen.h" #include "ingen/types.hpp" #include "sord/sordmm.hpp" @@ -75,7 +76,8 @@ public: * * @throw std::logic_error */ - virtual void serialise(SPtr<const Node> object); + virtual void serialise(SPtr<const Node> object, + Property::Graph context = Property::Graph::DEFAULT); /** Serialize an arc. * diff --git a/src/Serialiser.cpp b/src/Serialiser.cpp index 38a2c860..36d4a87f 100644 --- a/src/Serialiser.cpp +++ b/src/Serialiser.cpp @@ -277,7 +277,7 @@ Serialiser::Impl::path_rdf_node(const Raul::Path& path) } void -Serialiser::serialise(SPtr<const Node> object) +Serialiser::serialise(SPtr<const Node> object, Resource::Graph context) { if (!me->_model) { throw std::logic_error("serialise called without serialisation in progress"); @@ -289,9 +289,8 @@ Serialiser::serialise(SPtr<const Node> object) const Sord::URI plugin_id(me->_model->world(), object->plugin()->uri()); me->serialise_block(object, plugin_id, me->path_rdf_node(object->path())); } else if (object->graph_type() == Node::GraphType::PORT) { - me->serialise_port(object.get(), - Resource::Graph::DEFAULT, - me->path_rdf_node(object->path())); + me->serialise_port( + object.get(), context, me->path_rdf_node(object->path())); } else { me->serialise_properties(me->path_rdf_node(object->path()), object->properties()); |