From f63c29df622dd4f4fde6de3906ec53765117fb79 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Tue, 12 Dec 2006 23:30:38 +0000 Subject: Loading subpatches (ie not just into root). Initial patch metadata. Subpatch browsing (via double clicking modules). git-svn-id: http://svn.drobilla.net/lad/ingen@218 a436a847-0d15-0410-975c-d299462d15a1 --- src/progs/ingenuity/NodeModule.cpp | 10 ++++++++-- src/progs/ingenuity/PatchPortModule.cpp | 8 ++++---- src/progs/ingenuity/ThreadedLoader.cpp | 4 ++-- 3 files changed, 14 insertions(+), 8 deletions(-) (limited to 'src/progs/ingenuity') diff --git a/src/progs/ingenuity/NodeModule.cpp b/src/progs/ingenuity/NodeModule.cpp index 73b87b5b..bec6e89c 100644 --- a/src/progs/ingenuity/NodeModule.cpp +++ b/src/progs/ingenuity/NodeModule.cpp @@ -27,6 +27,7 @@ #include "RenameWindow.h" #include "PatchWindow.h" #include "WindowFactory.h" +#include "SubpatchModule.h" namespace Ingenuity { @@ -51,8 +52,13 @@ NodeModule::NodeModule(boost::shared_ptr canvas, SharedPtr NodeModule::create(boost::shared_ptr canvas, SharedPtr node) { - boost::shared_ptr ret = boost::shared_ptr( - new NodeModule(canvas, node)); + boost::shared_ptr ret; + + SharedPtr patch = PtrCast(node); + if (patch) + ret = boost::shared_ptr(new SubpatchModule(canvas, patch)); + else + ret = boost::shared_ptr(new NodeModule(canvas, node)); for (MetadataMap::const_iterator m = node->metadata().begin(); m != node->metadata().end(); ++m) ret->metadata_update(m->first, m->second); diff --git a/src/progs/ingenuity/PatchPortModule.cpp b/src/progs/ingenuity/PatchPortModule.cpp index 315aacab..e1fb37a8 100644 --- a/src/progs/ingenuity/PatchPortModule.cpp +++ b/src/progs/ingenuity/PatchPortModule.cpp @@ -68,13 +68,13 @@ PatchPortModule::create(boost::shared_ptr canvas, SharedPtrmetadata().begin(); m != port->metadata().end(); ++m) - ret->metadata_update(m->first, m->second); - - ret->m_patch_port = boost::shared_ptr(new Port(ret->shared_from_this(), port, true)); + ret->m_patch_port = boost::shared_ptr(new Port(ret, port, true)); ret->add_port(ret->m_patch_port); ret->resize(); + + for (MetadataMap::const_iterator m = port->metadata().begin(); m != port->metadata().end(); ++m) + ret->metadata_update(m->first, m->second); return ret; } diff --git a/src/progs/ingenuity/ThreadedLoader.cpp b/src/progs/ingenuity/ThreadedLoader.cpp index fbd64d3d..a3920665 100644 --- a/src/progs/ingenuity/ThreadedLoader.cpp +++ b/src/progs/ingenuity/ThreadedLoader.cpp @@ -73,9 +73,9 @@ ThreadedLoader::load_patch(bool merge, cerr << "FIXME: load under root only\n"; - _events.push_back(sigc::bind( + _events.push_back(sigc::hide_return(sigc::bind( sigc::mem_fun(_loader, &Loader::load), - data_base_uri, "/")); + data_base_uri, "/", "", engine_data))); _mutex.unlock(); -- cgit v1.2.1