/* This file is part of Ingen. Copyright 2007-2015 David Robillard Ingen is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or 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 Affero General Public License for details. You should have received a copy of the GNU Affero General Public License along with Ingen. If not, see . */ #include #include #include #include "ingen/Configuration.hpp" #include "ingen/Interface.hpp" #include "ingen/client/BlockModel.hpp" #include "ingen/client/GraphModel.hpp" #include "App.hpp" #include "Style.hpp" #include "GraphCanvas.hpp" #include "GraphPortModule.hpp" #include "GraphWindow.hpp" #include "Port.hpp" #include "PortMenu.hpp" #include "RenameWindow.hpp" #include "WidgetFactory.hpp" #include "WindowFactory.hpp" using namespace std; namespace Ingen { using namespace Client; namespace GUI { GraphPortModule::GraphPortModule(GraphCanvas& canvas, SPtr model) : Ganv::Module(canvas, "", 0, 0, false) // FIXME: coords? , _model(model) , _port(nullptr) { assert(model); assert(dynamic_ptr_cast(model->parent())); set_stacked(model->polyphonic()); if (model->is_input() && !model->is_numeric()) { set_is_source(true); } model->signal_property().connect( sigc::mem_fun(this, &GraphPortModule::property_changed)); signal_moved().connect( sigc::mem_fun(this, &GraphPortModule::store_location)); } GraphPortModule* GraphPortModule::create(GraphCanvas& canvas, SPtr model) { GraphPortModule* ret = new GraphPortModule(canvas, model); Port* port = Port::create(canvas.app(), *ret, model, true); ret->set_port(port); if (model->is_numeric()) { port->show_control(); } for (const auto& p : model->properties()) { ret->property_changed(p.first, p.second); } return ret; } App& GraphPortModule::app() const { return ((GraphCanvas*)canvas())->app(); } bool GraphPortModule::show_menu(GdkEventButton* ev) { return _port->show_menu(ev); } void GraphPortModule::store_location(double ax, double ay) { const URIs& uris = app().uris(); const Atom x(app().forge().make(static_cast(ax))); const Atom y(app().forge().make(static_cast(ay))); if (x != _model->get_property(uris.ingen_canvasX) || y != _model->get_property(uris.ingen_canvasY)) { app().interface()->put( _model->uri(), {{uris.ingen_canvasX, Property(x, Property::Graph::INTERNAL)}, {uris.ingen_canvasY, Property(y, Property::Graph::INTERNAL)}}); } } void GraphPortModule::show_human_names(bool b) { const URIs& uris = app().uris(); const Atom& name = _model->get_property(uris.lv2_name); if (b && name.type() == uris.forge.String) { set_name(name.ptr()); } else { set_name(_model->symbol().c_str()); } } void GraphPortModule::set_name(const std::string& n) { _port->set_label(n.c_str()); } void GraphPortModule::property_changed(const Raul::URI& key, const Atom& value) { const URIs& uris = app().uris(); if (value.type() == uris.forge.Float) { if (key == uris.ingen_canvasX) { move_to(value.get(), get_y()); } else if (key == uris.ingen_canvasY) { move_to(get_x(), value.get()); } } else if (value.type() == uris.forge.String) { if (key == uris.lv2_name && app().world()->conf().option("human-names").get()) { set_name(value.ptr()); } else if (key == uris.lv2_symbol && !app().world()->conf().option("human-names").get()) { set_name(value.ptr()); } } else if (value.type() == uris.forge.Bool) { if (key == uris.ingen_polyphonic) { set_stacked(value.get()); } } } void GraphPortModule::set_selected(gboolean b) { if (b != get_selected()) { Module::set_selected(b); } } } // namespace GUI } // namespace Ingen