From dc255319ff35012b892ed3ee2bb0d311ebe1a670 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Sat, 21 May 2011 00:32:35 +0000 Subject: Fix Gtk warnings (avoid loading top level of UI file). git-svn-id: http://svn.drobilla.net/lad/trunk/ingen@3305 a436a847-0d15-0410-975c-d299462d15a1 --- src/gui/App.cpp | 10 ++++------ src/gui/ControlPanel.cpp | 12 +++--------- src/gui/Controls.cpp | 4 +--- src/gui/NodeControlWindow.cpp | 3 +-- src/gui/NodeModule.cpp | 3 +-- src/gui/PatchCanvas.cpp | 2 +- src/gui/PatchPortModule.cpp | 3 +-- src/gui/PatchView.cpp | 3 +-- src/gui/Port.cpp | 3 +-- src/gui/WidgetFactory.hpp | 12 ++++++++++++ src/gui/WindowFactory.cpp | 20 ++++++++------------ 11 files changed, 34 insertions(+), 41 deletions(-) diff --git a/src/gui/App.cpp b/src/gui/App.cpp index 723c3cd8..99e0ee42 100644 --- a/src/gui/App.cpp +++ b/src/gui/App.cpp @@ -78,15 +78,13 @@ App::App(Ingen::Shared::World* world) , _world(world) , _enable_signal(true) { - Glib::RefPtr xml = WidgetFactory::create(); - Glib::set_application_name("Ingen"); gtk_window_set_default_icon_name("ingen"); - xml->get_widget_derived("connect_win", _connect_window); - xml->get_widget_derived("messages_win", _messages_window); - xml->get_widget_derived("patch_tree_win", _patch_tree_window); - xml->get_widget("about_win", _about_dialog); + WidgetFactory::get_widget_derived("connect_win", _connect_window); + WidgetFactory::get_widget_derived("messages_win", _messages_window); + WidgetFactory::get_widget_derived("patch_tree_win", _patch_tree_window); + WidgetFactory::get_widget("about_win", _about_dialog); _about_dialog->property_program_name() = "Ingen"; _about_dialog->property_logo_icon_name() = "ingen"; diff --git a/src/gui/ControlPanel.cpp b/src/gui/ControlPanel.cpp index c87f7c5d..a3964cf5 100644 --- a/src/gui/ControlPanel.cpp +++ b/src/gui/ControlPanel.cpp @@ -89,22 +89,16 @@ ControlPanel::add_port(SharedPtr pm) if (pm->is_input()) { if (pm->is_toggle()) { ToggleControl* tc; - Glib::RefPtr xml - = WidgetFactory::create("toggle_control"); - xml->get_widget_derived("toggle_control", tc); + WidgetFactory::get_widget_derived("toggle_control", tc); control = tc; } else if (pm->is_a(PortType::CONTROL) || pm->supports(App::instance().uris().atom_Float32)) { SliderControl* sc; - Glib::RefPtr xml - = WidgetFactory::create("control_strip"); - xml->get_widget_derived("control_strip", sc); + WidgetFactory::get_widget_derived("control_strip", sc); control = sc; } else if (pm->supports(App::instance().uris().atom_String)) { StringControl* sc; - Glib::RefPtr xml - = WidgetFactory::create("string_control"); - xml->get_widget_derived("string_control", sc); + WidgetFactory::get_widget_derived("string_control", sc); control = sc; } } diff --git a/src/gui/Controls.cpp b/src/gui/Controls.cpp index af4a139e..6ab0b3c3 100644 --- a/src/gui/Controls.cpp +++ b/src/gui/Controls.cpp @@ -106,10 +106,8 @@ Control::set_label(const string& name) void Control::menu_properties() { - Glib::RefPtr xml = WidgetFactory::create(); - PortPropertiesWindow* window; - xml->get_widget_derived("port_properties_win", window); + WidgetFactory::get_widget_derived("port_properties_win", window); window->present(_port_model); } diff --git a/src/gui/NodeControlWindow.cpp b/src/gui/NodeControlWindow.cpp index a99de9a8..547c2e1f 100644 --- a/src/gui/NodeControlWindow.cpp +++ b/src/gui/NodeControlWindow.cpp @@ -47,8 +47,7 @@ NodeControlWindow::NodeControlWindow(SharedPtr node, set_title(_node->plugin_model()->human_name() + " - Ingen"); - Glib::RefPtr xml = WidgetFactory::create("warehouse_win"); - xml->get_widget_derived("control_panel_vbox", _control_panel); + WidgetFactory::get_widget_derived("control_panel_vbox", _control_panel); show_all_children(); diff --git a/src/gui/NodeModule.cpp b/src/gui/NodeModule.cpp index 6e598b27..d65ae217 100644 --- a/src/gui/NodeModule.cpp +++ b/src/gui/NodeModule.cpp @@ -78,8 +78,7 @@ NodeModule::~NodeModule() void NodeModule::create_menu() { - Glib::RefPtr xml = WidgetFactory::create(); - xml->get_widget_derived("object_menu", _menu); + WidgetFactory::get_widget_derived("object_menu", _menu); _menu->init(_node); _menu->signal_embed_gui.connect( sigc::mem_fun(this, &NodeModule::embed_gui)); diff --git a/src/gui/PatchCanvas.cpp b/src/gui/PatchCanvas.cpp index 0a0adecd..6da4eb93 100644 --- a/src/gui/PatchCanvas.cpp +++ b/src/gui/PatchCanvas.cpp @@ -72,7 +72,7 @@ PatchCanvas::PatchCanvas(SharedPtr patch, int width, int heigh , _human_names(true) , _show_port_names(true) { - Glib::RefPtr xml = WidgetFactory::create(); + Glib::RefPtr xml = WidgetFactory::create("canvas_menu"); xml->get_widget("canvas_menu", _menu); xml->get_widget("canvas_menu_add_audio_input", _menu_add_audio_input); diff --git a/src/gui/PatchPortModule.cpp b/src/gui/PatchPortModule.cpp index 224a8f7e..df74626b 100644 --- a/src/gui/PatchPortModule.cpp +++ b/src/gui/PatchPortModule.cpp @@ -77,8 +77,7 @@ PatchPortModule::create(boost::shared_ptr canvas, void PatchPortModule::create_menu() { - Glib::RefPtr xml = WidgetFactory::create(); - xml->get_widget_derived("object_menu", _menu); + WidgetFactory::get_widget_derived("object_menu", _menu); _menu->init(_model, true); set_menu(_menu); diff --git a/src/gui/PatchView.cpp b/src/gui/PatchView.cpp index 04d6cf9c..19ff35d6 100644 --- a/src/gui/PatchView.cpp +++ b/src/gui/PatchView.cpp @@ -117,9 +117,8 @@ PatchView::set_patch(SharedPtr patch) SharedPtr PatchView::create(SharedPtr patch) { - const Glib::RefPtr& xml = WidgetFactory::create("patch_view_box"); PatchView* result = NULL; - xml->get_widget_derived("patch_view_box", result); + WidgetFactory::get_widget_derived("patch_view_box", result); assert(result); result->set_patch(patch); return SharedPtr(result); diff --git a/src/gui/Port.cpp b/src/gui/Port.cpp index 115afefc..484c461b 100644 --- a/src/gui/Port.cpp +++ b/src/gui/Port.cpp @@ -126,8 +126,7 @@ void Port::create_menu() { PortMenu* menu = NULL; - Glib::RefPtr xml = WidgetFactory::create(); - xml->get_widget_derived("object_menu", menu); + WidgetFactory::get_widget_derived("object_menu", menu); menu->init(model(), _flipped); set_menu(menu); } diff --git a/src/gui/WidgetFactory.hpp b/src/gui/WidgetFactory.hpp index 43525246..1d200d0b 100644 --- a/src/gui/WidgetFactory.hpp +++ b/src/gui/WidgetFactory.hpp @@ -35,6 +35,18 @@ public: static Glib::RefPtr create(const std::string& toplevel_widget=""); + template + static void get_widget(const Glib::ustring& name, T*& widget) { + Glib::RefPtr xml = create(name); + xml->get_widget(name, widget); + } + + template + static void get_widget_derived(const Glib::ustring& name, T*& widget) { + Glib::RefPtr xml = create(name); + xml->get_widget_derived(name, widget); + } + private: static void find_ui_file(); static Glib::ustring ui_filename; diff --git a/src/gui/WindowFactory.cpp b/src/gui/WindowFactory.cpp index 99cf9d1d..15788243 100644 --- a/src/gui/WindowFactory.cpp +++ b/src/gui/WindowFactory.cpp @@ -47,17 +47,15 @@ WindowFactory::WindowFactory() , _new_subpatch_win(NULL) , _properties_win(NULL) { - Glib::RefPtr xml = WidgetFactory::create(); - - xml->get_widget_derived("load_plugin_win", _load_plugin_win); - xml->get_widget_derived("load_patch_win", _load_patch_win); - xml->get_widget_derived("load_remote_patch_win", _load_remote_patch_win); - xml->get_widget_derived("new_subpatch_win", _new_subpatch_win); - xml->get_widget_derived("properties_win", _properties_win); - xml->get_widget_derived("rename_win", _rename_win); + WidgetFactory::get_widget_derived("load_plugin_win", _load_plugin_win); + WidgetFactory::get_widget_derived("load_patch_win", _load_patch_win); + WidgetFactory::get_widget_derived("load_remote_patch_win", _load_remote_patch_win); + WidgetFactory::get_widget_derived("new_subpatch_win", _new_subpatch_win); + WidgetFactory::get_widget_derived("properties_win", _properties_win); + WidgetFactory::get_widget_derived("rename_win", _rename_win); #ifdef HAVE_CURL - xml->get_widget_derived("upload_patch_win", _upload_patch_win); + WidgetFactory::get_widget_derived("upload_patch_win", _upload_patch_win); #endif } @@ -169,10 +167,8 @@ WindowFactory::new_patch_window(SharedPtr patch, { assert( !view || view->patch() == patch); - Glib::RefPtr xml = WidgetFactory::create("patch_win"); - PatchWindow* win = NULL; - xml->get_widget_derived("patch_win", win); + WidgetFactory::get_widget_derived("patch_win", win); assert(win); win->set_patch(patch, view); -- cgit v1.2.1