Mercurial > octave
view libgui/src/gui-preferences.h @ 31837:febd82d1a8de
use new macros to consistently delete copy and move member functions
Use new OCTAVE_DISABLE_COPY_MOVE macro to consistently disable copy
and move constructors and assignment operators. Consistently declare
deleted functions in public class sections.
Affected files: dw-main-window.h, gui-preferences.h, gui-settings.h,
qt-application.h, qt-interpreter-events.h, variable-editor-model.cc,
variable-editor-model.h, variable-editor.h, base-text-renderer.h,
c-file-ptr-stream.h, dynamic-ld.h, error.h, event-manager.h,
event-queue.h, fcn-info.h, ft-text-renderer.cc, gl-render.cc,
gl-render.h, graphics.cc, graphics.in.h, gzfstream.h, interpreter.cc,
interpreter.h, load-path.h, load-save.h, mex.cc, mxarray.h,
oct-fstrm.h, oct-hist.h, oct-iostrm.h, oct-prcstrm.h, oct-procbuf.h,
oct-stdstrm.h, oct-stream.cc, oct-stream.h, oct-strstrm.h, pager.h,
settings.h, stack-frame.cc, symscope.h, symtab.h, text-renderer.h,
url-handle-manager.h, __init_fltk__.cc, gzip.cc, cdef-class.cc,
cdef-manager.h, ov-builtin.h, ov-class.cc, ov-classdef.h,
ov-dld-fcn.h, ov-fcn.h, ov-mex-fcn.h, ov-typeinfo.h, ov-usr-fcn.h,
octave.h, anon-fcn-validator.h, lex.h, oct-parse.yy, parse.h,
profiler.h, pt-anon-scopes.h, pt-arg-list.h, pt-args-block.h,
pt-array-list.h, pt-assign.h, pt-binop.h, pt-bp.h, pt-cbinop.h,
pt-cell.h, pt-check.h, pt-classdef.h, pt-cmd.h, pt-colon.h,
pt-const.h, pt-decl.h, pt-eval.h, pt-except.h, pt-exp.h,
pt-fcn-handle.h, pt-id.h, pt-idx.h, pt-jump.h, pt-loop.h, pt-mat.h,
pt-misc.h, pt-pr-code.h, pt-select.h, pt-spmd.h, pt-stmt.h,
pt-tm-const.h, pt-unop.h, pt-walk.h, pt.h, token.h, Array-base.cc,
idx-vector.h, oct-fftw.h, sparse-chol.cc, sparse-qr.cc, oct-env.h,
action-container.h, cmd-edit.cc, cmd-edit.h, cmd-hist.h, oct-mutex.h,
oct-refcount.h, oct-shlib.cc, oct-sort.h, oct-string.h,
singleton-cleanup.h, unwind-prot.h, url-transfer.cc, and
url-transfer.h.
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Thu, 16 Feb 2023 14:43:18 -0500 |
parents | 21f9b34eb893 |
children | 17a09d2bbe0f |
line wrap: on
line source
//////////////////////////////////////////////////////////////////////// // // Copyright (C) 2017-2023 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_gui_preferences_h) #define octave_gui_preferences_h 1 #include "octave-config.h" #include <QStringList> #include <QStyle> #include <QTabWidget> #include <QTextCodec> #include <QVariant> // FIXME: Would it be possible/make sense to merge gui_pref and sc_pref // into a single class or to at least have them derived from a common // base class so we could have one global hash table that contains all // of them? // Structure for the definition of pairs: key and default value class gui_pref { public: // Default constructed gui_pref objects are invalid, but we need this // to create QHash objects that contain gui_pref objects. No invalid // gui_pref objects should acutally be used. gui_pref () = default; gui_pref (const QString& settings_key, const QVariant& def, bool ignore = false); gui_pref (const gui_pref&) = default; gui_pref& operator = (const gui_pref&) = default; ~gui_pref () = default; QString settings_key () const { return m_settings_key; } QVariant def () const { return m_def; } bool ignore () const { return m_ignore; } private: // The settings key name. QString m_settings_key; // The default value. QVariant m_def; // TRUE means always take the default. bool m_ignore; }; // FIXME: Is there a better/more modern way to manage this data than to // have this style of singleton class? // Allow lookup of gui_pref objects when we don't know the name at // compile time. class all_gui_preferences { public: all_gui_preferences () = default; OCTAVE_DISABLE_COPY_MOVE (all_gui_preferences) ~all_gui_preferences () = default; static void insert (const QString& settings_key, const gui_pref& pref); static const gui_pref value (const QString& settings_key); static QStringList keys (); private: // Map from shortcut identifier (settings key) to gui_pref object. QHash <QString, gui_pref> m_hash; void do_insert (const QString& settings_key, const gui_pref& pref); const gui_pref do_value (const QString& settings_key) const; QStringList do_keys () const; static void ensure_instance (); // Map from shortcut identifier (settings key) to sc_pref object. static all_gui_preferences *s_instance; }; // The version for shortcuts, where the default value is stored as a // combination of Qt:Keys (resutling in an unsigend int, when added) // or as one of the predefined standard key sequences. class sc_pref { public: // Default constructed sc_pref objects are invalid, but we need this // to create QHash objects that contain sc_pref objects. No invalid // sc_pref objects should acutally be used. sc_pref () = default; sc_pref (const QString& description, const QString& settings_key, Qt::Key def); sc_pref (const QString& description_arg, const QString& settings_key, unsigned int def); sc_pref (const QString& description_arg, const QString& settings_key, QKeySequence::StandardKey def_std); sc_pref (const sc_pref&) = default; sc_pref& operator = (const sc_pref&) = default; ~sc_pref () = default; QString description () const { return m_description; } QString settings_key () const { return m_settings_key; } unsigned int def () const { return m_def; } QKeySequence::StandardKey def_std () const { return m_def_std; } QKeySequence def_value () const; QString def_text () const; private: // Description of the shortcut. QString m_description; // The settings key name. QString m_settings_key; // The default as key. unsigned int m_def; // The default as standard key. QKeySequence::StandardKey m_def_std; }; // FIXME: Is there a better/more modern way to manage this data than to // have this style of singleton class? // Allow lookup of sc_pref objects when we don't know the name at // compile time. class all_shortcut_preferences { public: all_shortcut_preferences () = default; OCTAVE_DISABLE_COPY_MOVE (all_shortcut_preferences) ~all_shortcut_preferences () = default; static void insert (const QString& settings_key, const sc_pref& scpref); static const sc_pref value (const QString& settings_key); static QStringList keys (); private: // Map from shortcut identifier (settings key) to sc_pref object. QHash <QString, sc_pref> m_hash; void do_insert (const QString& settings_key, const sc_pref& scpref); const sc_pref do_value (const QString& settings_key) const; QStringList do_keys () const; static void ensure_instance (); // Map from shortcut identifier (settings key) to sc_pref object. static all_shortcut_preferences *s_instance; }; #endif