summaryrefslogtreecommitdiffstats
path: root/src/libs/gui/Port.cpp
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2007-09-21 04:01:33 +0000
committerDavid Robillard <d@drobilla.net>2007-09-21 04:01:33 +0000
commita1e97211b02cc1cd9509617cd3452d731ad7b512 (patch)
tree09fc6e10ce01b6975fc69f3f14bf031919264d80 /src/libs/gui/Port.cpp
parent2fd281a285e4b0bc31e0a0dc6f970359440612c8 (diff)
downloadingen-a1e97211b02cc1cd9509617cd3452d731ad7b512.tar.gz
ingen-a1e97211b02cc1cd9509617cd3452d731ad7b512.tar.bz2
ingen-a1e97211b02cc1cd9509617cd3452d731ad7b512.zip
Reimplement menu system to be picturey, glade loaded, heirarchial, code reusey, etc.
Patch port polyphony toggling. git-svn-id: http://svn.drobilla.net/lad/ingen@745 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/libs/gui/Port.cpp')
-rw-r--r--src/libs/gui/Port.cpp32
1 files changed, 14 insertions, 18 deletions
diff --git a/src/libs/gui/Port.cpp b/src/libs/gui/Port.cpp
index d5272878..5eae70c7 100644
--- a/src/libs/gui/Port.cpp
+++ b/src/libs/gui/Port.cpp
@@ -24,7 +24,8 @@
#include "Configuration.hpp"
#include "App.hpp"
#include "Port.hpp"
-using std::cerr; using std::endl;
+#include "PortMenu.hpp"
+#include "GladeFactory.hpp"
using namespace Ingen::Client;
@@ -34,20 +35,22 @@ namespace GUI {
/** @param flip Make an input port appear as an output port, and vice versa.
*/
-Port::Port(boost::shared_ptr<FlowCanvas::Module> module, SharedPtr<PortModel> pm, bool flip, bool destroyable)
-: FlowCanvas::Port(module,
- pm->path().name(),
- flip ? (!pm->is_input()) : pm->is_input(),
- App::instance().configuration()->get_port_color(pm.get())),
- _port_model(pm)
+Port::Port(boost::shared_ptr<FlowCanvas::Module> module, SharedPtr<PortModel> pm, bool flip)
+ : FlowCanvas::Port(module,
+ pm->path().name(),
+ flip ? (!pm->is_input()) : pm->is_input(),
+ App::instance().configuration()->get_port_color(pm.get()))
+ , _port_model(pm)
{
assert(module);
assert(_port_model);
- if (destroyable)
- _menu.items().push_back(Gtk::Menu_Helpers::MenuElem("Destroy",
- sigc::mem_fun(this, &Port::on_menu_destroy)));
-
+ PortMenu* menu = NULL;
+ Glib::RefPtr<Gnome::Glade::Xml> xml = GladeFactory::new_glade_reference();
+ xml->get_widget_derived("object_menu", menu);
+ menu->init(pm);
+ set_menu(menu);
+
_port_model->signal_renamed.connect(sigc::mem_fun(this, &Port::renamed));
if (pm->is_control()) {
@@ -70,13 +73,6 @@ Port::Port(boost::shared_ptr<FlowCanvas::Module> module, SharedPtr<PortModel> pm
void
-Port::on_menu_destroy()
-{
- App::instance().engine()->destroy(_port_model->path());
-}
-
-
-void
Port::renamed()
{
set_name(_port_model->path().name());