diff libgui/graphics/ToolBarButton.cc @ 27645:028205a91a07

eliminate global access to Octave resources in qt graphics classes Provide reference to base_qobject to qt graphics classes to eliminate need for accessing it through a global variable. * qt-graphics-toolkit.h, qt-graphics-toolkit.cc (qt_graphics_toolkit::m_octave_qobj): New member variable. (qt_graphics_toolkit::qt_graphics_toolkit): Accept reference to base_qobject as argument. (qt_graphics_toolkit::create_object): Pass m_octave_qobj to create functions for individual graphics objects. * __init_qt__.cc (__init__): Temporarily access base_qobject by calling octave::base_qobject::the_octave_qobject. Pass it to qt_graphics_toolkit constructor. * BaseControl.h, BaseControl.cc, ButtonControl.h, ButtonControl.cc, ButtonGroup.h, ButtonGroup.cc, Canvas.h, Canvas.cc, CheckBoxControl.h, CheckBoxControl.cc, Container.h, Container.cc, ContextMenu.h, ContextMenu.cc, EditControl.h, EditControl.cc, Figure.h, Figure.cc, GLCanvas.h, GLCanvas.cc, ListBoxControl.h, ListBoxControl.cc, Menu.h, Menu.cc, Panel.h, Panel.cc, PopupMenuControl.h, PopupMenuControl.cc, PushButtonControl.h, PushButtonControl.cc, PushTool.h, PushTool.cc, RadioButtonControl.h, RadioButtonControl.cc, SliderControl.h, SliderControl.cc, Table.h, Table.cc, TextControl.h, TextControl.cc, ToggleButtonControl.h, ToggleButtonControl.cc, ToggleTool.h, ToggleTool.cc, ToolBar.h, ToolBar.cc, ToolBarButton.h, ToolBarButton.cc, annotation-dialog.h, annotation-dialog.cc: Accept reference to base_qobject in create function and constructors for graphics objects. Eliminate global access to GUI resources.
author John W. Eaton <jwe@octave.org>
date Tue, 05 Nov 2019 13:28:45 -0500
parents 8b6e928e0705
children 2a506bc4a7af
line wrap: on
line diff
--- a/libgui/graphics/ToolBarButton.cc	Tue Nov 05 08:31:06 2019 -0500
+++ b/libgui/graphics/ToolBarButton.cc	Tue Nov 05 13:28:45 2019 -0500
@@ -25,6 +25,7 @@
 // this file.
 
 #include <QAction>
+#include <QIcon>
 #include <QWidget>
 
 #include "ToolBarButton.h"
@@ -33,17 +34,10 @@
 
 namespace QtHandles
 {
-  static QIcon get_icon (const std::string& name)
-  {
-    octave::resource_manager& rmgr
-      = octave::__get_resource_manager__ ("get_icon");
-
-    return rmgr.icon (QString::fromStdString (name));
-  }
-
   template <typename T>
-  ToolBarButton<T>::ToolBarButton (const graphics_object& go, QAction *action)
-    : Object (go, action), m_separator (nullptr)
+  ToolBarButton<T>::ToolBarButton (octave::base_qobject& oct_qobj,
+                                   const graphics_object& go, QAction *action)
+    : Object (go, action), m_octave_qobj (oct_qobj), m_separator (nullptr)
   {
     typename T::properties& tp = properties<T> ();
 
@@ -154,4 +148,12 @@
       }
   }
 
+  template <typename T>
+  QIcon ToolBarButton<T>::get_icon (const std::string& name)
+  {
+    octave::resource_manager& rmgr = m_octave_qobj.get_resource_manager ();
+
+    return rmgr.icon (QString::fromStdString (name));
+  }
+
 }