Mercurial > octave
view libgui/src/qt-application.h @ 31695:5749674b826e
store constant shortcut data in global QHash object
This change is a step toward removing the shortcut_manager class
* gui-preferences-sc.cc, gui-preferences.cc: New files.
* libgui/src/module.mk: Update.
* gui-preferences-sc.h, gui-preferences-sc.cc:
Declare shortcut objects extern instead of const and initialize them
in source file instead of header.
(all_shortcut_preferences): New singleton class for global shortcut data.
* gui-preferences.h, gui-preferences.cc (sc_pref): Define as class
with private data members. Disallow modifying data members by only
providing accessor functions instead of making data members constant.
Change all uses.
(sc_pref::m_description, sc_pref::description): New data member and
accessor function.
(sc_pref::sc_pref): Include description in constructor argument list.
Change all uses. Store shortcut info in global
all_shortcut_preferences hash when creating sc_pref objects. Use
settings_keys instead of keys to avoid confusion between the index key
use for QSettings and keyboard keys.
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Sun, 25 Dec 2022 20:37:53 -0500 |
parents | deb553ac2c54 |
children | 5f11de0e7440 |
line wrap: on
line source
//////////////////////////////////////////////////////////////////////// // // Copyright (C) 2012-2022 The Octave Project Developers // // See the file COPYRIGHT.md in the top-level directory of this // distribution or <https://octave.org/copyright/>. // // This file is part of Octave. // // Octave 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 3 of the License, or // (at your option) any later version. // // Octave 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 more details. // // You should have received a copy of the GNU General Public License // along with Octave; see the file COPYING. If not, see // <https://www.gnu.org/licenses/>. // //////////////////////////////////////////////////////////////////////// #if ! defined (octave_qt_application_h) #define octave_qt_application_h 1 #include <string> #include "octave.h" OCTAVE_BEGIN_NAMESPACE(octave) // Programming Note: This file must not include any Qt headers. Any // Qt header files required by the qt_application::execute function // must be included only in the corresponding .cc file. //! This class inherits from the pure-virtual base class //! application and provides an implementation of the //! application::execute method that starts an interface to Octave //! that is based on Qt. It may start a command-line interface that //! allows Qt graphics to be used or it may start an interface that //! provides the full GUI experience. class OCTGUI_API qt_application : public application { public: qt_application (const std::string& organization_name, const std::string& application_name, const std::string& application_version, int argc, char **argv); qt_application (int argc, char **argv); // No copying, at least not yet. qt_application (const qt_application&) = delete; qt_application& operator = (const qt_application&) = delete; ~qt_application (void) = default; // Should we start the GUI or fall back to the CLI? bool start_gui_p (void) const; int execute (void); bool gui_running (void) const { return m_gui_running; } void gui_running (bool arg) { m_gui_running = arg; } private: // If TRUE, the GUI should be started. bool m_gui_running = false; }; OCTAVE_END_NAMESPACE(octave) #endif