diff options
author | David Robillard <d@drobilla.net> | 2011-12-04 07:25:09 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2011-12-04 07:25:09 +0000 |
commit | a9bea6c1d981d6bc53817fce6db4c9bc0f1e1e62 (patch) | |
tree | e1a98f16528a9f085774f824152e02c942646f9a | |
parent | 314822117b6af5c2468f2a7772092591cd15044b (diff) | |
download | patchage-a9bea6c1d981d6bc53817fce6db4c9bc0f1e1e62.tar.gz patchage-a9bea6c1d981d6bc53817fce6db4c9bc0f1e1e62.tar.bz2 patchage-a9bea6c1d981d6bc53817fce6db4c9bc0f1e1e62.zip |
Move module ports down to C level.
Add STL-style port iteration API to Module.
git-svn-id: http://svn.drobilla.net/lad/trunk/patchage@3795 a436a847-0d15-0410-975c-d299462d15a1
-rw-r--r-- | src/PatchageCanvas.cpp | 20 | ||||
-rw-r--r-- | src/PatchageModule.cpp | 6 |
2 files changed, 15 insertions, 11 deletions
diff --git a/src/PatchageCanvas.cpp b/src/PatchageCanvas.cpp index 36b207d..d20add5 100644 --- a/src/PatchageCanvas.cpp +++ b/src/PatchageCanvas.cpp @@ -133,6 +133,16 @@ struct RemovePortsData { }; static void +delete_port_if_matches(FlowCanvasPort* port, void* cdata) +{ + RemovePortsData* data = (RemovePortsData*)cdata; + PatchagePort* pport = dynamic_cast<PatchagePort*>(Glib::wrap(port)); + if (pport && data->pred(pport)) { + delete pport; + } +} + +static void remove_ports_matching(FlowCanvasNode* node, void* cdata) { if (!FLOW_CANVAS_IS_MODULE(node)) { @@ -146,14 +156,8 @@ remove_ports_matching(FlowCanvasNode* node, void* cdata) } RemovePortsData* data = (RemovePortsData*)cdata; - - FlowCanvas::Module::Ports ports = pmodule->ports(); // copy - for (FlowCanvas::Module::Ports::iterator p = ports.begin(); - p != ports.end(); ++p) { - if (data->pred(dynamic_cast<PatchagePort*>(*p))) { - delete *p; - } - } + + pmodule->for_each_port(delete_port_if_matches, data); if (pmodule->num_ports() == 0) { data->empty.insert(pmodule); diff --git a/src/PatchageModule.cpp b/src/PatchageModule.cpp index 85538cd..4576261 100644 --- a/src/PatchageModule.cpp +++ b/src/PatchageModule.cpp @@ -45,7 +45,7 @@ PatchageModule::update_menu() if (_type == InputOutput) { bool has_in = false; bool has_out = false; - for (Ports::const_iterator p = _ports.begin(); p != _ports.end(); ++p) { + for (const_iterator p = begin(); p != end(); ++p) { if ((*p)->is_input()) { has_in = true; } else { @@ -145,14 +145,14 @@ PatchageModule::remove_port(FlowCanvas::Port* port) void PatchageModule::menu_disconnect_all() { - for (Ports::iterator p = _ports.begin(); p != _ports.end(); ++p) + for (iterator p = begin(); p != end(); ++p) (*p)->disconnect_all(); } PatchagePort* PatchageModule::get_port(const std::string& name) { - for (Ports::const_iterator p = _ports.begin(); p != _ports.end(); ++p) { + for (iterator p = begin(); p != end(); ++p) { if ((*p)->get_label() == name) { return dynamic_cast<PatchagePort*>(*p); } |