summaryrefslogtreecommitdiffstats
path: root/src/progs/ingenuity/NodeModule.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/progs/ingenuity/NodeModule.cpp')
-rw-r--r--src/progs/ingenuity/NodeModule.cpp151
1 files changed, 0 insertions, 151 deletions
diff --git a/src/progs/ingenuity/NodeModule.cpp b/src/progs/ingenuity/NodeModule.cpp
deleted file mode 100644
index dd03fde8..00000000
--- a/src/progs/ingenuity/NodeModule.cpp
+++ /dev/null
@@ -1,151 +0,0 @@
-/* This file is part of Ingen.
- * Copyright (C) 2007 Dave Robillard <http://drobilla.net>
- *
- * Ingen is free software; you can redistribute it and/or modify it under the
- * terms of the GNU General Public License as published by the Free Software
- * Foundation; either version 2 of the License, or (at your option) any later
- * version.
- *
- * Ingen is distributed in the hope that it will be useful, but WITHOUT ANY
- * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
- * FOR A PARTICULAR PURPOSE. See the GNU General Public License for details.
- *
- * You should have received a copy of the GNU General Public License along
- * with this program; if not, write to the Free Software Foundation, Inc.,
- * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
- */
-
-#include <cassert>
-#include <raul/Atom.h>
-#include "interface/EngineInterface.h"
-#include "client/PatchModel.h"
-#include "client/NodeModel.h"
-#include "App.h"
-#include "NodeModule.h"
-#include "PatchCanvas.h"
-#include "Port.h"
-#include "GladeFactory.h"
-#include "RenameWindow.h"
-#include "PatchWindow.h"
-#include "WindowFactory.h"
-#include "SubpatchModule.h"
-#include "NodeControlWindow.h"
-
-namespace Ingenuity {
-
-
-NodeModule::NodeModule(boost::shared_ptr<PatchCanvas> canvas, SharedPtr<NodeModel> node)
-: LibFlowCanvas::Module(canvas, node->path().name()),
- _node(node),
- _menu(node)
-{
- assert(_node);
-
- if (node->polyphonic()) {
- set_border_width(2.0);
- }
-
- node->new_port_sig.connect(sigc::bind(sigc::mem_fun(this, &NodeModule::add_port), true));
- node->removed_port_sig.connect(sigc::mem_fun(this, &NodeModule::remove_port));
- node->metadata_update_sig.connect(sigc::mem_fun(this, &NodeModule::metadata_update));
-
- signal_clicked.connect(sigc::mem_fun(this, &NodeModule::on_click));
-}
-
-
-NodeModule::~NodeModule()
-{
- NodeControlWindow* win = App::instance().window_factory()->control_window(_node);
-
- if (win) {
- // Should remove from window factory via signal
- delete win;
- }
-}
-
-
-boost::shared_ptr<NodeModule>
-NodeModule::create(boost::shared_ptr<PatchCanvas> canvas, SharedPtr<NodeModel> node)
-{
- boost::shared_ptr<NodeModule> ret;
-
- SharedPtr<PatchModel> patch = PtrCast<PatchModel>(node);
- if (patch)
- ret = boost::shared_ptr<NodeModule>(new SubpatchModule(canvas, patch));
- else
- ret = boost::shared_ptr<NodeModule>(new NodeModule(canvas, node));
-
- for (MetadataMap::const_iterator m = node->metadata().begin(); m != node->metadata().end(); ++m)
- ret->metadata_update(m->first, m->second);
-
- for (PortModelList::const_iterator p = node->ports().begin(); p != node->ports().end(); ++p)
- ret->add_port(*p, false);
-
- ret->resize();
-
- return ret;
-}
-
-
-void
-NodeModule::add_port(SharedPtr<PortModel> port, bool resize_to_fit)
-{
- Module::add_port(boost::shared_ptr<Port>(new Port(
- PtrCast<NodeModule>(shared_from_this()), port)));
-
- if (resize_to_fit)
- resize();
-}
-
-
-void
-NodeModule::remove_port(SharedPtr<PortModel> port)
-{
- SharedPtr<LibFlowCanvas::Port> p = Module::remove_port(port->path().name());
- p.reset();
-}
-
-
-void
-NodeModule::show_control_window()
-{
- App::instance().window_factory()->present_controls(_node);
-}
-
-
-void
-NodeModule::store_location()
-{
- const float x = static_cast<float>(property_x());
- const float y = static_cast<float>(property_y());
-
- const Atom& existing_x = _node->get_metadata("ingenuity:canvas-x");
- const Atom& existing_y = _node->get_metadata("ingenuity:canvas-y");
-
- if (existing_x.type() != Atom::FLOAT || existing_y.type() != Atom::FLOAT
- || existing_x.get_float() != x || existing_y.get_float() != y) {
- App::instance().engine()->set_metadata(_node->path(), "ingenuity:canvas-x", Atom(x));
- App::instance().engine()->set_metadata(_node->path(), "ingenuity:canvas-y", Atom(y));
- }
-}
-
-
-void
-NodeModule::on_click(GdkEventButton* event)
-{
- if (event->button == 3)
- _menu.popup(event->button, event->time);
-}
-
-
-void
-NodeModule::metadata_update(const string& key, const Atom& value)
-{
- if (key == "ingenuity:canvas-x" && value.type() == Atom::FLOAT)
- move_to(value.get_float(), property_y());
- else if (key == "ingenuity:canvas-y" && value.type() == Atom::FLOAT)
- move_to(property_x(), value.get_float());
-}
-
-
-} // namespace Ingenuity