File: MultiSettings.h

package info (click to toggle)
js8call 2.5.2%2Bds-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 24,720 kB
  • sloc: cpp: 562,651; sh: 898; python: 132; ansic: 102; makefile: 4
file content (108 lines) | stat: -rw-r--r-- 3,629 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
#ifndef MULTISETTINGS_HPP__
#define MULTISETTINGS_HPP__

#include <QObject>
#include <QString>
#include <QVariant>

#include "JS8_Include/pimpl_h.h"

class QSettings;
class QMainWindow;
class QMenu;

//
// MultiSettings - Manage multiple configuration names
//
// Responsibilities:
//
//  MultiSettings allows a  Qt application to be  run with alternative
//  settings as  stored in a QSettings  INI style file. As  far as the
//  application is  concerned it uses the  QSettings instance returned
//  by the MultiSettings::settings() method as  if it were the one and
//  only  QSettings object.   The alternative  settings are  stored as
//  QSettings groups which  are children of a root  level group called
//  MultiSettings. The  current settings are themselves  stored at the
//  root so the QSettings group  name MultiSettings is reserved.  Also
//  at the  root level a key  called CurrentMultiSettingsConfiguration
//  is reserved to store the current configuration name.
//
//
// Example Usage:
//
//  #include <QApplication>
//  #include "MultiSettings.h"
//  #include "MyMainWindow.h"
//
//  int main (int argc, char * argv[]) {
//    QApplication a {argc, argv};
//    MultiSettings multi_settings;
//    int result;
//    do {
//      MyMainWindow main_window {&multi_settings};
//      main_window.show ();
//      result = a.exec ();
//    } while (!result && !multi_settings.exit ());
//    return result;
//  }
//
//  In  the main  window call  MultiSettings::create_menu_actions() to
//  populate an existing QMenu widget with the configuration switching
//  and maintenance actions.  This would normally be done  in the main
//  window class constructor:
//
//  MyMainWindow::MyMainWindow (MultiSettings * multi_settings) {
//    QSettings * settings {multi_settings->settings ()};
//    // ...
//    multi_settings->create_menu_actions (this, ui->configurations_menu);
//    // ...
//  }
//

class MultiSettings : public QObject {
    Q_OBJECT

  public:
    // config_name will be  selected if it is  an existing configuration
    // name otherwise  the last used  configuration will be  selected or
    // the default configuration if none exist
    explicit MultiSettings(QString const &config_name = QString{});

    MultiSettings(MultiSettings const &) = delete;
    MultiSettings &operator=(MultiSettings const &) = delete;
    ~MultiSettings();

    // Add multiple configurations navigation and maintenance actions to
    // a provided  menu. The provided  main window object  instance will
    // have its close() function called when a "Switch To" configuration
    // action is triggered.
    void create_menu_actions(QMainWindow *, QMenu *);

    // switch to this configuration if it exists
    Q_SLOT void select_configuration(QString const &name);
    QString configuration_name() const;

    // Access to the QSettings object instance.
    QSettings *settings();

    // Access to values in a common section
    QVariant common_value(QString const &key,
                          QVariant const &default_value = QVariant{}) const;
    void set_common_value(QString const &key, QVariant const &value);
    void remove_common_value(QString const &key);

    // Call this to  determine if the application is  terminating, if it
    // returns  false  then  the   application  main  window  should  be
    // recreated,  shown  and  the application  exec()  function  called
    // again.
    bool exit();

    // emitted when the name of the current configuration changes
    Q_SIGNAL void configurationNameChanged(QString name) const;

  private:
    class impl;
    pimpl<impl> m_;
};

#endif