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
|
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
/*
Rosegarden
A MIDI and audio sequencer and musical notation editor.
This program is Copyright 2000-2008
Guillaume Laurent <glaurent@telegraph-road.org>,
Chris Cannam <cannam@all-day-breakfast.com>,
Richard Bown <richard.bown@ferventsoftware.com>
The moral rights of Guillaume Laurent, Chris Cannam, and Richard
Bown to claim authorship of this work have been asserted.
Parts of the configuration classes are taken from KMail.
Copyright (C) 2000 The KMail Development Team.
Other copyrights also apply to some parts of this work. Please
see the AUTHORS file and individual file headers for details.
This program 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 2 of the
License, or (at your option) any later version. See the file
COPYING included with this distribution for more information.
*/
#ifndef _RG_CONFIGURATIONPAGE_H_
#define _RG_CONFIGURATIONPAGE_H_
#include <tqwidget.h>
class KConfig;
namespace Rosegarden
{
class RosegardenGUIDoc;
/**
* This class borrowed from KMail
* (c) 2000 The KMail Development Team
*/
class ConfigurationPage : public TQWidget
{
Q_OBJECT
public:
ConfigurationPage(RosegardenGUIDoc *doc,
TQWidget *parent=0, const char *name=0)
: TQWidget(parent, name), m_doc(doc), m_cfg(0), m_pageIndex(0) {}
ConfigurationPage(KConfig *cfg,
TQWidget *parent=0, const char *name=0)
: TQWidget(parent, name), m_doc(0), m_cfg(cfg), m_pageIndex(0) {}
ConfigurationPage(RosegardenGUIDoc *doc, KConfig *cfg,
TQWidget *parent=0, const char *name=0)
: TQWidget(parent, name), m_doc(doc), m_cfg(cfg), m_pageIndex(0) {}
virtual ~ConfigurationPage() {};
/**
* Should set the page up (ie. read the setting from the @ref
* KConfig object into the widgets) after creating it in the
* constructor. Called from @ref ConfigureDialog.
*/
// virtual void setup() = 0;
/**
* Should apply the changed settings (ie. read the settings from
* the widgets into the @ref KConfig object). Called from @ref
* ConfigureDialog.
*/
virtual void apply() = 0;
/**
* Should cleanup any temporaries after cancel. The default
* implementation does nothing. Called from @ref
* ConfigureDialog.
*/
virtual void dismiss() {}
void setPageIndex( int aPageIndex ) { m_pageIndex = aPageIndex; }
int pageIndex() const { return m_pageIndex; }
protected:
//--------------- Data members ---------------------------------
RosegardenGUIDoc* m_doc;
KConfig* m_cfg;
int m_pageIndex;
};
}
#endif
|