-rw-r--r-- | microkde/kdeui/kmainwindow.cpp | 1 | ||||
-rw-r--r-- | microkde/kdeui/kmainwindow.h | 5 |
2 files changed, 4 insertions, 2 deletions
diff --git a/microkde/kdeui/kmainwindow.cpp b/microkde/kdeui/kmainwindow.cpp index bd5a2cc..3ae4c87 100644 --- a/microkde/kdeui/kmainwindow.cpp +++ b/microkde/kdeui/kmainwindow.cpp | |||
@@ -1,994 +1,995 @@ | |||
1 | /* This file is part of the KDE libraries | 1 | /* This file is part of the KDE libraries |
2 | Copyright | 2 | Copyright |
3 | (C) 2000 Reginald Stadlbauer (reggie@kde.org) | 3 | (C) 2000 Reginald Stadlbauer (reggie@kde.org) |
4 | (C) 1997 Stephan Kulow (coolo@kde.org) | 4 | (C) 1997 Stephan Kulow (coolo@kde.org) |
5 | (C) 1997-2000 Sven Radej (radej@kde.org) | 5 | (C) 1997-2000 Sven Radej (radej@kde.org) |
6 | (C) 1997-2000 Matthias Ettrich (ettrich@kde.org) | 6 | (C) 1997-2000 Matthias Ettrich (ettrich@kde.org) |
7 | (C) 1999 Chris Schlaeger (cs@kde.org) | 7 | (C) 1999 Chris Schlaeger (cs@kde.org) |
8 | (C) 2002 Joseph Wenninger (jowenn@kde.org) | 8 | (C) 2002 Joseph Wenninger (jowenn@kde.org) |
9 | 9 | ||
10 | This library is free software; you can redistribute it and/or | 10 | This library is free software; you can redistribute it and/or |
11 | modify it under the terms of the GNU Library General Public | 11 | modify it under the terms of the GNU Library General Public |
12 | License version 2 as published by the Free Software Foundation. | 12 | License version 2 as published by the Free Software Foundation. |
13 | 13 | ||
14 | This library is distributed in the hope that it will be useful, | 14 | This library is distributed in the hope that it will be useful, |
15 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 15 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
17 | Library General Public License for more details. | 17 | Library General Public License for more details. |
18 | 18 | ||
19 | You should have received a copy of the GNU Library General Public License | 19 | You should have received a copy of the GNU Library General Public License |
20 | along with this library; see the file COPYING.LIB. If not, write to | 20 | along with this library; see the file COPYING.LIB. If not, write to |
21 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | 21 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
22 | Boston, MA 02111-1307, USA. | 22 | Boston, MA 02111-1307, USA. |
23 | */ | 23 | */ |
24 | #include <qobjectlist.h> | 24 | #include <qobjectlist.h> |
25 | #include <qstringlist.h> | 25 | #include <qstringlist.h> |
26 | #include <qtimer.h> | 26 | #include <qtimer.h> |
27 | #include <qmenubar.h> | 27 | #include <qmenubar.h> |
28 | #include <qstatusbar.h> | 28 | #include <qstatusbar.h> |
29 | #include <qapplication.h> | 29 | #include <qapplication.h> |
30 | 30 | ||
31 | 31 | ||
32 | #include "kdebug.h" | 32 | #include "kdebug.h" |
33 | #include "kmainwindow.h" | 33 | #include "kmainwindow.h" |
34 | #include "kglobalsettings.h" | 34 | #include "kglobalsettings.h" |
35 | #include "kactioncollection.h" | 35 | #include "kactioncollection.h" |
36 | 36 | ||
37 | class KMainWindowPrivate { | 37 | class KMainWindowPrivate { |
38 | public: | 38 | public: |
39 | //US bool showHelpMenu:1; | 39 | //US bool showHelpMenu:1; |
40 | 40 | ||
41 | bool autoSaveSettings:1; | 41 | bool autoSaveSettings:1; |
42 | bool settingsDirty:1; | 42 | bool settingsDirty:1; |
43 | bool autoSaveWindowSize:1; | 43 | bool autoSaveWindowSize:1; |
44 | bool care_about_geometry:1; | 44 | bool care_about_geometry:1; |
45 | QString autoSaveGroup; | 45 | QString autoSaveGroup; |
46 | //US KAccel * kaccel; | 46 | //US KAccel * kaccel; |
47 | //US KMainWindowInterface *m_interface; | 47 | //US KMainWindowInterface *m_interface; |
48 | KDEPrivate::ToolBarHandler *toolBarHandler; | 48 | KDEPrivate::ToolBarHandler *toolBarHandler; |
49 | QTimer* settingsTimer; | 49 | QTimer* settingsTimer; |
50 | KToggleAction *showStatusBarAction; | 50 | KToggleAction *showStatusBarAction; |
51 | QRect defaultWindowSize; | 51 | QRect defaultWindowSize; |
52 | }; | 52 | }; |
53 | 53 | ||
54 | static bool no_query_exit = false; | 54 | static bool no_query_exit = false; |
55 | 55 | ||
56 | KMainWindow::KMainWindow( QWidget* parent, const char *name, WFlags f ) | 56 | KMainWindow::KMainWindow( QWidget* parent, const char *name, WFlags f ) |
57 | : QMainWindow( parent, name ) /*LR, f ) with the default widget flag we cannot have fastload */ /*US, KXMLGUIBuilder( this ), helpMenu2( 0 ), factory_( 0 )*/ | 57 | : QMainWindow( parent, name ) /*LR, f ) with the default widget flag we cannot have fastload */ /*US, KXMLGUIBuilder( this ), helpMenu2( 0 ), factory_( 0 )*/ |
58 | { | 58 | { |
59 | mQToolBar = 0; | 59 | mQToolBar = 0; |
60 | initKMainWindow(name); | 60 | initKMainWindow(name); |
61 | } | 61 | } |
62 | 62 | ||
63 | void KMainWindow::parseGeometry(bool parsewidth) | 63 | void KMainWindow::parseGeometry(bool parsewidth) |
64 | { | 64 | { |
65 | //US the following code is not getting used in the embedded version !! So disable it for now | 65 | //US the following code is not getting used in the embedded version !! So disable it for now |
66 | /*US | 66 | /*US |
67 | 67 | ||
68 | assert ( !kapp->geometryArgument().isNull() ); | 68 | assert ( !kapp->geometryArgument().isNull() ); |
69 | assert ( d->care_about_geometry ); | 69 | assert ( d->care_about_geometry ); |
70 | 70 | ||
71 | #ifndef Q_WS_QWS | 71 | #ifndef Q_WS_QWS |
72 | // FIXME: (E) Implement something similar for Qt Embedded (or decide we don't need it) | 72 | // FIXME: (E) Implement something similar for Qt Embedded (or decide we don't need it) |
73 | int x, y; | 73 | int x, y; |
74 | int w, h; | 74 | int w, h; |
75 | int m = XParseGeometry( kapp->geometryArgument().latin1(), &x, &y, (unsigned int*)&w, (unsigned int*)&h); | 75 | int m = XParseGeometry( kapp->geometryArgument().latin1(), &x, &y, (unsigned int*)&w, (unsigned int*)&h); |
76 | if (parsewidth) { | 76 | if (parsewidth) { |
77 | QSize minSize = minimumSize(); | 77 | QSize minSize = minimumSize(); |
78 | QSize maxSize = maximumSize(); | 78 | QSize maxSize = maximumSize(); |
79 | if ( (m & WidthValue) == 0 ) | 79 | if ( (m & WidthValue) == 0 ) |
80 | w = width(); | 80 | w = width(); |
81 | if ( (m & HeightValue) == 0 ) | 81 | if ( (m & HeightValue) == 0 ) |
82 | h = height(); | 82 | h = height(); |
83 | w = QMIN(w,maxSize.width()); | 83 | w = QMIN(w,maxSize.width()); |
84 | h = QMIN(h,maxSize.height()); | 84 | h = QMIN(h,maxSize.height()); |
85 | w = QMAX(w,minSize.width()); | 85 | w = QMAX(w,minSize.width()); |
86 | h = QMAX(h,minSize.height()); | 86 | h = QMAX(h,minSize.height()); |
87 | resize(w, h); | 87 | resize(w, h); |
88 | } else { | 88 | } else { |
89 | if ( parsewidth && (m & XValue) == 0 ) | 89 | if ( parsewidth && (m & XValue) == 0 ) |
90 | x = geometry().x(); | 90 | x = geometry().x(); |
91 | if ( parsewidth && (m & YValue) == 0 ) | 91 | if ( parsewidth && (m & YValue) == 0 ) |
92 | y = geometry().y(); | 92 | y = geometry().y(); |
93 | if ( (m & XNegative) ) | 93 | if ( (m & XNegative) ) |
94 | x = KApplication::desktop()->width() + x - w; | 94 | x = KApplication::desktop()->width() + x - w; |
95 | if ( (m & YNegative) ) | 95 | if ( (m & YNegative) ) |
96 | y = KApplication::desktop()->height() + y - h; | 96 | y = KApplication::desktop()->height() + y - h; |
97 | move(x, y); | 97 | move(x, y); |
98 | } | 98 | } |
99 | #endif | 99 | #endif |
100 | */ | 100 | */ |
101 | } | 101 | } |
102 | 102 | ||
103 | KMainWindow::~KMainWindow() | 103 | KMainWindow::~KMainWindow() |
104 | { | 104 | { |
105 | delete d->settingsTimer; | 105 | delete d->settingsTimer; |
106 | QMenuBar* mb = internalMenuBar(); | 106 | QMenuBar* mb = internalMenuBar(); |
107 | delete mb; | 107 | delete mb; |
108 | //US delete d->m_interface; | 108 | //US delete d->m_interface; |
109 | 109 | ||
110 | delete d; | 110 | delete d; |
111 | //US memberList->remove( this ); | 111 | //US memberList->remove( this ); |
112 | } | 112 | } |
113 | 113 | ||
114 | void KMainWindow::initKMainWindow(const char *name) | 114 | void KMainWindow::initKMainWindow(const char *name) |
115 | { | 115 | { |
116 | setDockMenuEnabled( FALSE ); | 116 | setDockMenuEnabled( FALSE ); |
117 | //US mHelpMenu = 0; | 117 | //US mHelpMenu = 0; |
118 | 118 | ||
119 | //US kapp->setTopWidget( this ); | 119 | //US kapp->setTopWidget( this ); |
120 | actionCollection()->setWidget( this ); | 120 | actionCollection()->setWidget( this ); |
121 | //US connect(kapp, SIGNAL(shutDown()), this, SLOT(shuttingDown())); | 121 | //US connect(kapp, SIGNAL(shutDown()), this, SLOT(shuttingDown())); |
122 | //US if( !memberList ) | 122 | //US if( !memberList ) |
123 | //US memberList = new QPtrList<KMainWindow>; | 123 | //US memberList = new QPtrList<KMainWindow>; |
124 | /*US | 124 | /*US |
125 | 125 | ||
126 | if ( !ksm ) | 126 | if ( !ksm ) |
127 | ksm = ksmd.setObject(new KMWSessionManaged()); | 127 | ksm = ksmd.setObject(new KMWSessionManaged()); |
128 | // set a unique object name. Required by session management. | 128 | // set a unique object name. Required by session management. |
129 | QCString objname; | 129 | QCString objname; |
130 | QCString s; | 130 | QCString s; |
131 | int unusedNumber; | 131 | int unusedNumber; |
132 | if ( !name ) | 132 | if ( !name ) |
133 | { // no name given | 133 | { // no name given |
134 | objname = kapp->instanceName() + "-mainwindow#"; | 134 | objname = kapp->instanceName() + "-mainwindow#"; |
135 | s = objname + '1'; // start adding number immediately | 135 | s = objname + '1'; // start adding number immediately |
136 | unusedNumber = 1; | 136 | unusedNumber = 1; |
137 | } | 137 | } |
138 | else if( name[ strlen( name ) - 1 ] == '#' ) | 138 | else if( name[ strlen( name ) - 1 ] == '#' ) |
139 | { // trailing # - always add a number | 139 | { // trailing # - always add a number |
140 | objname = name; | 140 | objname = name; |
141 | s = objname + '1'; // start adding number immediately | 141 | s = objname + '1'; // start adding number immediately |
142 | unusedNumber = 1; | 142 | unusedNumber = 1; |
143 | } | 143 | } |
144 | else | 144 | else |
145 | { | 145 | { |
146 | objname = name; | 146 | objname = name; |
147 | s = objname; | 147 | s = objname; |
148 | unusedNumber = 0; // add numbers only when needed | 148 | unusedNumber = 0; // add numbers only when needed |
149 | } | 149 | } |
150 | for(;;) { | 150 | for(;;) { |
151 | QWidgetList* list = kapp->topLevelWidgets(); | 151 | QWidgetList* list = kapp->topLevelWidgets(); |
152 | QWidgetListIt it( *list ); | 152 | QWidgetListIt it( *list ); |
153 | bool found = false; | 153 | bool found = false; |
154 | for( QWidget* w = it.current(); | 154 | for( QWidget* w = it.current(); |
155 | w != NULL; | 155 | w != NULL; |
156 | ++it, w = it.current()) | 156 | ++it, w = it.current()) |
157 | if( w != this && w->name() == s ) | 157 | if( w != this && w->name() == s ) |
158 | { | 158 | { |
159 | found = true; | 159 | found = true; |
160 | break; | 160 | break; |
161 | } | 161 | } |
162 | delete list; | 162 | delete list; |
163 | if( !found ) | 163 | if( !found ) |
164 | break; | 164 | break; |
165 | s.setNum( ++unusedNumber ); | 165 | s.setNum( ++unusedNumber ); |
166 | s = objname + s; | 166 | s = objname + s; |
167 | } | 167 | } |
168 | setName( s ); | 168 | setName( s ); |
169 | memberList->append( this ); | 169 | memberList->append( this ); |
170 | */ | 170 | */ |
171 | 171 | ||
172 | d = new KMainWindowPrivate; | 172 | d = new KMainWindowPrivate; |
173 | //US d->showHelpMenu = true; | 173 | //US d->showHelpMenu = true; |
174 | d->settingsDirty = false; | 174 | d->settingsDirty = false; |
175 | d->autoSaveSettings = false; | 175 | d->autoSaveSettings = false; |
176 | d->autoSaveWindowSize = true; // for compatibility | 176 | d->autoSaveWindowSize = true; // for compatibility |
177 | //US d->kaccel = actionCollection()->kaccel(); | 177 | //US d->kaccel = actionCollection()->kaccel(); |
178 | d->toolBarHandler = 0; | 178 | d->toolBarHandler = 0; |
179 | d->settingsTimer = 0; | 179 | d->settingsTimer = 0; |
180 | d->showStatusBarAction = NULL; | 180 | d->showStatusBarAction = NULL; |
181 | /*US | 181 | /*US |
182 | if ((d->care_about_geometry == beeing_first)) { | 182 | if ((d->care_about_geometry == beeing_first)) { |
183 | beeing_first = false; | 183 | beeing_first = false; |
184 | if ( kapp->geometryArgument().isNull() ) // if there is no geometry, it doesn't mater | 184 | if ( kapp->geometryArgument().isNull() ) // if there is no geometry, it doesn't mater |
185 | d->care_about_geometry = false; | 185 | d->care_about_geometry = false; |
186 | else | 186 | else |
187 | parseGeometry(false); | 187 | parseGeometry(false); |
188 | } | 188 | } |
189 | */ | 189 | */ |
190 | d->care_about_geometry = false; | 190 | d->care_about_geometry = false; |
191 | 191 | ||
192 | //US setCaption( kapp->caption() ); | 192 | //US setCaption( kapp->caption() ); |
193 | // attach dcop interface | 193 | // attach dcop interface |
194 | //US d->m_interface = new KMainWindowInterface(this); | 194 | //US d->m_interface = new KMainWindowInterface(this); |
195 | 195 | ||
196 | //US if (!kapp->authorize("movable_toolbars")) | 196 | //US if (!kapp->authorize("movable_toolbars")) |
197 | //US setDockWindowsMovable(false); | 197 | //US setDockWindowsMovable(false); |
198 | } | 198 | } |
199 | 199 | ||
200 | KAction *KMainWindow::toolBarMenuAction() | 200 | KAction *KMainWindow::toolBarMenuAction() |
201 | { | 201 | { |
202 | if ( !d->toolBarHandler ) | 202 | if ( !d->toolBarHandler ) |
203 | return 0; | 203 | return 0; |
204 | 204 | ||
205 | return d->toolBarHandler->toolBarMenuAction(); | 205 | return d->toolBarHandler->toolBarMenuAction(); |
206 | } | 206 | } |
207 | 207 | ||
208 | bool KMainWindow::canBeRestored( int number ) | 208 | bool KMainWindow::canBeRestored( int number ) |
209 | { | 209 | { |
210 | /*US we do not have and want to save sessioninformation. Use info from the default | 210 | /*US we do not have and want to save sessioninformation. Use info from the default |
211 | application config. | 211 | application config. |
212 | */ | 212 | */ |
213 | //US if ( !kapp->isRestored() ) | 213 | //US if ( !kapp->isRestored() ) |
214 | //US return FALSE; | 214 | //US return FALSE; |
215 | //US KConfig *config = kapp->sessionConfig(); | 215 | //US KConfig *config = kapp->sessionConfig(); |
216 | KConfig *config = KGlobal::config(); | 216 | KConfig *config = KGlobal::config(); |
217 | if ( !config ) | 217 | if ( !config ) |
218 | return FALSE; | 218 | return FALSE; |
219 | config->setGroup( QString::fromLatin1("Number") ); | 219 | config->setGroup( QString::fromLatin1("Number") ); |
220 | int n = config->readNumEntry( QString::fromLatin1("NumberOfWindows") , 1 ); | 220 | int n = config->readNumEntry( QString::fromLatin1("NumberOfWindows") , 1 ); |
221 | return number >= 1 && number <= n; | 221 | return number >= 1 && number <= n; |
222 | 222 | ||
223 | } | 223 | } |
224 | 224 | ||
225 | const QString KMainWindow::classNameOfToplevel( int number ) | 225 | const QString KMainWindow::classNameOfToplevel( int number ) |
226 | { | 226 | { |
227 | /*US we do not have and want to save sessioninformation. Use info from the default | 227 | /*US we do not have and want to save sessioninformation. Use info from the default |
228 | application config. | 228 | application config. |
229 | */ | 229 | */ |
230 | //US if ( !kapp->isRestored() ) | 230 | //US if ( !kapp->isRestored() ) |
231 | //US return QString::null; | 231 | //US return QString::null; |
232 | //US KConfig *config = kapp->sessionConfig(); | 232 | //US KConfig *config = kapp->sessionConfig(); |
233 | KConfig *config = KGlobal::config(); | 233 | KConfig *config = KGlobal::config(); |
234 | if ( !config ) | 234 | if ( !config ) |
235 | return QString::null; | 235 | return QString::null; |
236 | QString s; | 236 | QString s; |
237 | s.setNum( number ); | 237 | s.setNum( number ); |
238 | s.prepend( QString::fromLatin1("WindowProperties") ); | 238 | s.prepend( QString::fromLatin1("WindowProperties") ); |
239 | config->setGroup( s ); | 239 | config->setGroup( s ); |
240 | if ( !config->hasKey( QString::fromLatin1("ClassName") ) ) | 240 | if ( !config->hasKey( QString::fromLatin1("ClassName") ) ) |
241 | return QString::null; | 241 | return QString::null; |
242 | else | 242 | else |
243 | return config->readEntry( QString::fromLatin1("ClassName") ); | 243 | return config->readEntry( QString::fromLatin1("ClassName") ); |
244 | } | 244 | } |
245 | 245 | ||
246 | bool KMainWindow::restore( int number, bool show ) | 246 | bool KMainWindow::restore( int number, bool show ) |
247 | { | 247 | { |
248 | /*US we do not have and want to save sessioninformation. Use info from the default | 248 | /*US we do not have and want to save sessioninformation. Use info from the default |
249 | application config. | 249 | application config. |
250 | */ | 250 | */ |
251 | if ( !canBeRestored( number ) ) | 251 | if ( !canBeRestored( number ) ) |
252 | return FALSE; | 252 | return FALSE; |
253 | //US KConfig *config = kapp->sessionConfig(); | 253 | //US KConfig *config = kapp->sessionConfig(); |
254 | KConfig *config = KGlobal::config(); | 254 | KConfig *config = KGlobal::config(); |
255 | 255 | ||
256 | if ( readPropertiesInternal( config, number ) ){ | 256 | if ( readPropertiesInternal( config, number ) ){ |
257 | if ( show ) | 257 | if ( show ) |
258 | KMainWindow::show(); | 258 | KMainWindow::show(); |
259 | return FALSE; | 259 | return FALSE; |
260 | } | 260 | } |
261 | return FALSE; | 261 | return FALSE; |
262 | 262 | ||
263 | } | 263 | } |
264 | 264 | ||
265 | void KMainWindow::setCaption( const QString &caption ) | 265 | void KMainWindow::setCaption( const QString &caption ) |
266 | { | 266 | { |
267 | //US setPlainCaption( kapp->makeStdCaption(caption) ); | 267 | //US setPlainCaption( kapp->makeStdCaption(caption) ); |
268 | setPlainCaption( caption ); | 268 | setPlainCaption( caption ); |
269 | } | 269 | } |
270 | 270 | ||
271 | void KMainWindow::setCaption( const QString &caption, bool modified ) | 271 | void KMainWindow::setCaption( const QString &caption, bool modified ) |
272 | { | 272 | { |
273 | //US setPlainCaption( kapp->makeStdCaption(caption, true, modified) ); | 273 | //US setPlainCaption( kapp->makeStdCaption(caption, true, modified) ); |
274 | setPlainCaption( caption + "modified:" ); | 274 | setPlainCaption( caption + "modified:" ); |
275 | } | 275 | } |
276 | 276 | ||
277 | void KMainWindow::setPlainCaption( const QString &caption ) | 277 | void KMainWindow::setPlainCaption( const QString &caption ) |
278 | { | 278 | { |
279 | QMainWindow::setCaption( caption ); | 279 | QMainWindow::setCaption( caption ); |
280 | #ifndef Q_WS_QWS | 280 | #ifndef Q_WS_QWS |
281 | //US the following is disabled for the embedded version | 281 | //US the following is disabled for the embedded version |
282 | //US NETWinInfo info( qt_xdisplay(), winId(), qt_xrootwin(), 0 ); | 282 | //US NETWinInfo info( qt_xdisplay(), winId(), qt_xrootwin(), 0 ); |
283 | //US info.setName( caption.utf8().data() ); | 283 | //US info.setName( caption.utf8().data() ); |
284 | #endif | 284 | #endif |
285 | } | 285 | } |
286 | 286 | ||
287 | void KMainWindow::slotStateChanged(const QString &newstate) | 287 | void KMainWindow::slotStateChanged(const QString &newstate) |
288 | { | 288 | { |
289 | stateChanged(newstate, KXMLGUIClient::StateNoReverse); | 289 | stateChanged(newstate, KXMLGUIClient::StateNoReverse); |
290 | } | 290 | } |
291 | 291 | ||
292 | /* | 292 | /* |
293 | * Get rid of this for KDE 4.0 | 293 | * Get rid of this for KDE 4.0 |
294 | */ | 294 | */ |
295 | void KMainWindow::slotStateChanged(const QString &newstate, | 295 | void KMainWindow::slotStateChanged(const QString &newstate, |
296 | KXMLGUIClient::ReverseStateChange reverse) | 296 | KXMLGUIClient::ReverseStateChange reverse) |
297 | { | 297 | { |
298 | stateChanged(newstate, reverse); | 298 | stateChanged(newstate, reverse); |
299 | } | 299 | } |
300 | 300 | ||
301 | void KMainWindow::closeEvent ( QCloseEvent *e ) | 301 | void KMainWindow::closeEvent ( QCloseEvent *e ) |
302 | { | 302 | { |
303 | //qDebug("MainWindow::closeEvent "); | ||
303 | // Save settings if auto-save is enabled, and settings have changed | 304 | // Save settings if auto-save is enabled, and settings have changed |
304 | if (d->settingsDirty && d->autoSaveSettings) | 305 | if (d->settingsDirty && d->autoSaveSettings) |
305 | saveAutoSaveSettings(); | 306 | saveAutoSaveSettings(); |
306 | 307 | ||
307 | if (queryClose()) { | 308 | if (queryClose()) { |
308 | e->accept(); | 309 | e->accept(); |
309 | 310 | ||
310 | int not_withdrawn = 0; | 311 | int not_withdrawn = 0; |
311 | /*US | 312 | /*US |
312 | QPtrListIterator<KMainWindow> it(*KMainWindow::memberList); | 313 | QPtrListIterator<KMainWindow> it(*KMainWindow::memberList); |
313 | for (it.toFirst(); it.current(); ++it){ | 314 | for (it.toFirst(); it.current(); ++it){ |
314 | if ( !it.current()->isHidden() && it.current()->isTopLevel() && it.current() != this ) | 315 | if ( !it.current()->isHidden() && it.current()->isTopLevel() && it.current() != this ) |
315 | not_withdrawn++; | 316 | not_withdrawn++; |
316 | } | 317 | } |
317 | */ | 318 | */ |
318 | if ( !no_query_exit && not_withdrawn <= 0 ) { // last window close accepted? | 319 | if ( !no_query_exit && not_withdrawn <= 0 ) { // last window close accepted? |
319 | /*US | 320 | /*US |
320 | if ( queryExit() && !kapp->sessionSaving()) { // Yes, Quit app? | 321 | if ( queryExit() && !kapp->sessionSaving()) { // Yes, Quit app? |
321 | // don't call queryExit() twice | 322 | // don't call queryExit() twice |
322 | disconnect(kapp, SIGNAL(shutDown()), this, SLOT(shuttingDown())); | 323 | disconnect(kapp, SIGNAL(shutDown()), this, SLOT(shuttingDown())); |
323 | kapp->deref(); // ...and quit aplication. | 324 | kapp->deref(); // ...and quit aplication. |
324 | } else { | 325 | } else { |
325 | // cancel closing, it's stupid to end up with no windows at all.... | 326 | // cancel closing, it's stupid to end up with no windows at all.... |
326 | e->ignore(); | 327 | e->ignore(); |
327 | } | 328 | } |
328 | */ | 329 | */ |
329 | //US we have no sessionmanagement. Simply close app. | 330 | //US we have no sessionmanagement. Simply close app. |
330 | if ( queryExit() ) { // Yes, Quit app? | 331 | if ( queryExit() ) { // Yes, Quit app? |
331 | qDebug("KMainWindow::closeEvent: Exit application ???"); | 332 | qDebug("KMainWindow::closeEvent: Exit application ???"); |
332 | // don't call queryExit() twice | 333 | // don't call queryExit() twice |
333 | //US disconnect(kapp, SIGNAL(shutDown()), this, SLOT(shuttingDown())); | 334 | //US disconnect(kapp, SIGNAL(shutDown()), this, SLOT(shuttingDown())); |
334 | } | 335 | } |
335 | 336 | ||
336 | } | 337 | } |
337 | } | 338 | } |
338 | } | 339 | } |
339 | 340 | ||
340 | bool KMainWindow::queryExit() | 341 | bool KMainWindow::queryExit() |
341 | { | 342 | { |
342 | return TRUE; | 343 | return TRUE; |
343 | } | 344 | } |
344 | 345 | ||
345 | bool KMainWindow::queryClose() | 346 | bool KMainWindow::queryClose() |
346 | { | 347 | { |
347 | return TRUE; | 348 | return TRUE; |
348 | } | 349 | } |
349 | 350 | ||
350 | void KMainWindow::saveGlobalProperties( KConfig* ) | 351 | void KMainWindow::saveGlobalProperties( KConfig* ) |
351 | { | 352 | { |
352 | } | 353 | } |
353 | 354 | ||
354 | void KMainWindow::readGlobalProperties( KConfig* ) | 355 | void KMainWindow::readGlobalProperties( KConfig* ) |
355 | { | 356 | { |
356 | } | 357 | } |
357 | 358 | ||
358 | void KMainWindow::savePropertiesInternal( KConfig *config, int number ) | 359 | void KMainWindow::savePropertiesInternal( KConfig *config, int number ) |
359 | { | 360 | { |
360 | bool oldASWS = d->autoSaveWindowSize; | 361 | bool oldASWS = d->autoSaveWindowSize; |
361 | d->autoSaveWindowSize = true; // make saveMainWindowSettings save the window size | 362 | d->autoSaveWindowSize = true; // make saveMainWindowSettings save the window size |
362 | 363 | ||
363 | QString s; | 364 | QString s; |
364 | s.setNum(number); | 365 | s.setNum(number); |
365 | s.prepend(QString::fromLatin1("WindowProperties")); | 366 | s.prepend(QString::fromLatin1("WindowProperties")); |
366 | config->setGroup(s); | 367 | config->setGroup(s); |
367 | 368 | ||
368 | // store objectName, className, Width and Height for later restoring | 369 | // store objectName, className, Width and Height for later restoring |
369 | // (Only useful for session management) | 370 | // (Only useful for session management) |
370 | config->writeEntry(QString::fromLatin1("ObjectName"), name()); | 371 | config->writeEntry(QString::fromLatin1("ObjectName"), name()); |
371 | config->writeEntry(QString::fromLatin1("ClassName"), className()); | 372 | config->writeEntry(QString::fromLatin1("ClassName"), className()); |
372 | 373 | ||
373 | saveMainWindowSettings(config); // Menubar, statusbar and Toolbar settings. | 374 | saveMainWindowSettings(config); // Menubar, statusbar and Toolbar settings. |
374 | 375 | ||
375 | s.setNum(number); | 376 | s.setNum(number); |
376 | config->setGroup(s); | 377 | config->setGroup(s); |
377 | saveProperties(config); | 378 | saveProperties(config); |
378 | 379 | ||
379 | d->autoSaveWindowSize = oldASWS; | 380 | d->autoSaveWindowSize = oldASWS; |
380 | } | 381 | } |
381 | 382 | ||
382 | void KMainWindow::setStandardToolBarMenuEnabled( bool enable ) | 383 | void KMainWindow::setStandardToolBarMenuEnabled( bool enable ) |
383 | { | 384 | { |
384 | if ( enable ) | 385 | if ( enable ) |
385 | { | 386 | { |
386 | if ( d->toolBarHandler ) | 387 | if ( d->toolBarHandler ) |
387 | return; | 388 | return; |
388 | 389 | ||
389 | d->toolBarHandler = new KDEPrivate::ToolBarHandler( this ); | 390 | d->toolBarHandler = new KDEPrivate::ToolBarHandler( this ); |
390 | 391 | ||
391 | /*US if ( factory() ) | 392 | /*US if ( factory() ) |
392 | factory()->addClient( d->toolBarHandler ); | 393 | factory()->addClient( d->toolBarHandler ); |
393 | */ | 394 | */ |
394 | } | 395 | } |
395 | else | 396 | else |
396 | { | 397 | { |
397 | if ( !d->toolBarHandler ) | 398 | if ( !d->toolBarHandler ) |
398 | return; | 399 | return; |
399 | /*US | 400 | /*US |
400 | if ( factory() ) | 401 | if ( factory() ) |
401 | factory()->removeClient( d->toolBarHandler ); | 402 | factory()->removeClient( d->toolBarHandler ); |
402 | */ | 403 | */ |
403 | delete d->toolBarHandler; | 404 | delete d->toolBarHandler; |
404 | d->toolBarHandler = 0; | 405 | d->toolBarHandler = 0; |
405 | } | 406 | } |
406 | 407 | ||
407 | } | 408 | } |
408 | 409 | ||
409 | bool KMainWindow::isStandardToolBarMenuEnabled() const | 410 | bool KMainWindow::isStandardToolBarMenuEnabled() const |
410 | { | 411 | { |
411 | return ( d->toolBarHandler != 0 ); | 412 | return ( d->toolBarHandler != 0 ); |
412 | } | 413 | } |
413 | 414 | ||
414 | void KMainWindow::createStandardStatusBarAction(){ | 415 | void KMainWindow::createStandardStatusBarAction(){ |
415 | if(!d->showStatusBarAction){ | 416 | if(!d->showStatusBarAction){ |
416 | d->showStatusBarAction = KStdAction::showStatusbar(this, SLOT(setSettingsDirty()), actionCollection()); | 417 | d->showStatusBarAction = KStdAction::showStatusbar(this, SLOT(setSettingsDirty()), actionCollection()); |
417 | connect(d->showStatusBarAction, SIGNAL(toggled(bool)), statusBar(), SLOT(setShown(bool))); | 418 | connect(d->showStatusBarAction, SIGNAL(toggled(bool)), statusBar(), SLOT(setShown(bool))); |
418 | if(internalStatusBar()) | 419 | if(internalStatusBar()) |
419 | d->showStatusBarAction->setChecked(!internalStatusBar()->isHidden()); | 420 | d->showStatusBarAction->setChecked(!internalStatusBar()->isHidden()); |
420 | } | 421 | } |
421 | } | 422 | } |
422 | 423 | ||
423 | QToolBar *KMainWindow::tBar( ) | 424 | QToolBar *KMainWindow::tBar( ) |
424 | { | 425 | { |
425 | if ( ! mQToolBar ) | 426 | if ( ! mQToolBar ) |
426 | mQToolBar = new QToolBar( this ); | 427 | mQToolBar = new QToolBar( this ); |
427 | return mQToolBar; | 428 | return mQToolBar; |
428 | } | 429 | } |
429 | 430 | ||
430 | KToolBar *KMainWindow::toolBar( const char * name ) | 431 | KToolBar *KMainWindow::toolBar( const char * name ) |
431 | { | 432 | { |
432 | 433 | ||
433 | if (!name) | 434 | if (!name) |
434 | name = "mainToolBar"; | 435 | name = "mainToolBar"; |
435 | KToolBar *tb = (KToolBar*)child( name, "KToolBar" ); | 436 | KToolBar *tb = (KToolBar*)child( name, "KToolBar" ); |
436 | if ( tb ) | 437 | if ( tb ) |
437 | return tb; | 438 | return tb; |
438 | bool honor_mode = (name == "mainToolBar"); | 439 | bool honor_mode = (name == "mainToolBar"); |
439 | 440 | ||
440 | /*US | 441 | /*US |
441 | if ( builderClient() ) | 442 | if ( builderClient() ) |
442 | return new KToolBar(this, name, honor_mode); // XMLGUI constructor | 443 | return new KToolBar(this, name, honor_mode); // XMLGUI constructor |
443 | else | 444 | else |
444 | */ | 445 | */ |
445 | return new KToolBar(this, Top, false, name, honor_mode ); // non-XMLGUI | 446 | return new KToolBar(this, Top, false, name, honor_mode ); // non-XMLGUI |
446 | } | 447 | } |
447 | 448 | ||
448 | QPtrListIterator<KToolBar> KMainWindow::toolBarIterator() | 449 | QPtrListIterator<KToolBar> KMainWindow::toolBarIterator() |
449 | { | 450 | { |
450 | toolbarList.clear(); | 451 | toolbarList.clear(); |
451 | QPtrList<QToolBar> lst; | 452 | QPtrList<QToolBar> lst; |
452 | for ( int i = (int)QMainWindow::Unmanaged; i <= (int)Minimized; ++i ) { | 453 | for ( int i = (int)QMainWindow::Unmanaged; i <= (int)Minimized; ++i ) { |
453 | lst = toolBars( (ToolBarDock)i ); | 454 | lst = toolBars( (ToolBarDock)i ); |
454 | for ( QToolBar *tb = lst.first(); tb; tb = lst.next() ) { | 455 | for ( QToolBar *tb = lst.first(); tb; tb = lst.next() ) { |
455 | if ( !tb->inherits( "KToolBar" ) ) | 456 | if ( !tb->inherits( "KToolBar" ) ) |
456 | continue; | 457 | continue; |
457 | toolbarList.append( (KToolBar*)tb ); | 458 | toolbarList.append( (KToolBar*)tb ); |
458 | } | 459 | } |
459 | } | 460 | } |
460 | return QPtrListIterator<KToolBar>( toolbarList ); | 461 | return QPtrListIterator<KToolBar>( toolbarList ); |
461 | } | 462 | } |
462 | 463 | ||
463 | void KMainWindow::setAutoSaveSettings( const QString & groupName, bool saveWindowSize ) | 464 | void KMainWindow::setAutoSaveSettings( const QString & groupName, bool saveWindowSize ) |
464 | { | 465 | { |
465 | d->autoSaveSettings = true; | 466 | d->autoSaveSettings = true; |
466 | d->autoSaveGroup = groupName; | 467 | d->autoSaveGroup = groupName; |
467 | d->autoSaveWindowSize = saveWindowSize; | 468 | d->autoSaveWindowSize = saveWindowSize; |
468 | // Get notified when the user moves a toolbar around | 469 | // Get notified when the user moves a toolbar around |
469 | //US connect( this, SIGNAL( dockWindowPositionChanged( QDockWindow * ) ), | 470 | //US connect( this, SIGNAL( dockWindowPositionChanged( QDockWindow * ) ), |
470 | //US this, SLOT( setSettingsDirty() ) ); | 471 | //US this, SLOT( setSettingsDirty() ) ); |
471 | connect( this, SIGNAL( toolBarPositionChanged(QToolBar *) ), | 472 | connect( this, SIGNAL( toolBarPositionChanged(QToolBar *) ), |
472 | this, SLOT( setSettingsDirty() ) ); | 473 | this, SLOT( setSettingsDirty() ) ); |
473 | 474 | ||
474 | 475 | ||
475 | // Get default values | 476 | // Get default values |
476 | //US int scnum = QApplication::desktop()->screenNumber(parentWidget()); | 477 | //US int scnum = QApplication::desktop()->screenNumber(parentWidget()); |
477 | //US QRect desk = QApplication::desktop()->screenGeometry(scnum); | 478 | //US QRect desk = QApplication::desktop()->screenGeometry(scnum); |
478 | QRect desk = KGlobalSettings::desktopGeometry(0); | 479 | QRect desk = KGlobalSettings::desktopGeometry(0); |
479 | 480 | ||
480 | d->defaultWindowSize = QRect(desk.width(), width(), desk.height(), height()); | 481 | d->defaultWindowSize = QRect(desk.width(), width(), desk.height(), height()); |
481 | // Now read the previously saved settings | 482 | // Now read the previously saved settings |
482 | applyMainWindowSettings( KGlobal::config(), groupName ); | 483 | applyMainWindowSettings( KGlobal::config(), groupName ); |
483 | } | 484 | } |
484 | 485 | ||
485 | 486 | ||
486 | void KMainWindow::resetAutoSaveSettings() | 487 | void KMainWindow::resetAutoSaveSettings() |
487 | { | 488 | { |
488 | d->autoSaveSettings = false; | 489 | d->autoSaveSettings = false; |
489 | if ( d->settingsTimer ) | 490 | if ( d->settingsTimer ) |
490 | d->settingsTimer->stop(); | 491 | d->settingsTimer->stop(); |
491 | } | 492 | } |
492 | 493 | ||
493 | bool KMainWindow::autoSaveSettings() const | 494 | bool KMainWindow::autoSaveSettings() const |
494 | { | 495 | { |
495 | return d->autoSaveSettings; | 496 | return d->autoSaveSettings; |
496 | } | 497 | } |
497 | 498 | ||
498 | QString KMainWindow::autoSaveGroup() const | 499 | QString KMainWindow::autoSaveGroup() const |
499 | { | 500 | { |
500 | return d->autoSaveGroup; | 501 | return d->autoSaveGroup; |
501 | } | 502 | } |
502 | 503 | ||
503 | void KMainWindow::saveAutoSaveSettings() | 504 | void KMainWindow::saveAutoSaveSettings() |
504 | { | 505 | { |
505 | ASSERT( d->autoSaveSettings ); | 506 | ASSERT( d->autoSaveSettings ); |
506 | //kdDebug(200) << "KMainWindow::saveAutoSaveSettings -> saving settings" << endl; | 507 | //kdDebug(200) << "KMainWindow::saveAutoSaveSettings -> saving settings" << endl; |
507 | saveMainWindowSettings( KGlobal::config(), d->autoSaveGroup ); | 508 | saveMainWindowSettings( KGlobal::config(), d->autoSaveGroup ); |
508 | KGlobal::config()->sync(); | 509 | KGlobal::config()->sync(); |
509 | d->settingsDirty = false; | 510 | d->settingsDirty = false; |
510 | if ( d->settingsTimer ) | 511 | if ( d->settingsTimer ) |
511 | d->settingsTimer->stop(); | 512 | d->settingsTimer->stop(); |
512 | } | 513 | } |
513 | 514 | ||
514 | void KMainWindow::createGUI( const QString &xmlfile, bool _conserveMemory ) | 515 | void KMainWindow::createGUI( const QString &xmlfile, bool _conserveMemory ) |
515 | { | 516 | { |
516 | // disabling the updates prevents unnecessary redraws | 517 | // disabling the updates prevents unnecessary redraws |
517 | setUpdatesEnabled( false ); | 518 | setUpdatesEnabled( false ); |
518 | 519 | ||
519 | // just in case we are rebuilding, let's remove our old client | 520 | // just in case we are rebuilding, let's remove our old client |
520 | //US guiFactory()->removeClient( this ); | 521 | //US guiFactory()->removeClient( this ); |
521 | 522 | ||
522 | // make sure to have an empty GUI | 523 | // make sure to have an empty GUI |
523 | QMenuBar* mb = internalMenuBar(); | 524 | QMenuBar* mb = internalMenuBar(); |
524 | if ( mb ) | 525 | if ( mb ) |
525 | mb->clear(); | 526 | mb->clear(); |
526 | 527 | ||
527 | (void)toolBarIterator(); // make sure toolbarList is most-up-to-date | 528 | (void)toolBarIterator(); // make sure toolbarList is most-up-to-date |
528 | toolbarList.setAutoDelete( true ); | 529 | toolbarList.setAutoDelete( true ); |
529 | toolbarList.clear(); | 530 | toolbarList.clear(); |
530 | toolbarList.setAutoDelete( false ); | 531 | toolbarList.setAutoDelete( false ); |
531 | /*US | 532 | /*US |
532 | // don't build a help menu unless the user ask for it | 533 | // don't build a help menu unless the user ask for it |
533 | if (d->showHelpMenu) { | 534 | if (d->showHelpMenu) { |
534 | // we always want a help menu | 535 | // we always want a help menu |
535 | if (helpMenu2 == 0) | 536 | if (helpMenu2 == 0) |
536 | helpMenu2 = new KHelpMenu(this, instance()->aboutData(), true, | 537 | helpMenu2 = new KHelpMenu(this, instance()->aboutData(), true, |
537 | actionCollection()); | 538 | actionCollection()); |
538 | } | 539 | } |
539 | 540 | ||
540 | // we always want to load in our global standards file | 541 | // we always want to load in our global standards file |
541 | setXMLFile( locate( "config", "ui/ui_standards.rc", instance() ) ); | 542 | setXMLFile( locate( "config", "ui/ui_standards.rc", instance() ) ); |
542 | 543 | ||
543 | // now, merge in our local xml file. if this is null, then that | 544 | // now, merge in our local xml file. if this is null, then that |
544 | // means that we will be only using the global file | 545 | // means that we will be only using the global file |
545 | if ( !xmlfile.isNull() ) { | 546 | if ( !xmlfile.isNull() ) { |
546 | setXMLFile( xmlfile, true ); | 547 | setXMLFile( xmlfile, true ); |
547 | } else { | 548 | } else { |
548 | QString auto_file(instance()->instanceName() + "ui.rc"); | 549 | QString auto_file(instance()->instanceName() + "ui.rc"); |
549 | setXMLFile( auto_file, true ); | 550 | setXMLFile( auto_file, true ); |
550 | } | 551 | } |
551 | 552 | ||
552 | // make sure we don't have any state saved already | 553 | // make sure we don't have any state saved already |
553 | setXMLGUIBuildDocument( QDomDocument() ); | 554 | setXMLGUIBuildDocument( QDomDocument() ); |
554 | 555 | ||
555 | // do the actual GUI building | 556 | // do the actual GUI building |
556 | guiFactory()->addClient( this ); | 557 | guiFactory()->addClient( this ); |
557 | 558 | ||
558 | // try and get back *some* of our memory | 559 | // try and get back *some* of our memory |
559 | if ( _conserveMemory ) | 560 | if ( _conserveMemory ) |
560 | { | 561 | { |
561 | // before freeing the memory allocated by the DOM document we also | 562 | // before freeing the memory allocated by the DOM document we also |
562 | // free all memory allocated internally in the KXMLGUIFactory for | 563 | // free all memory allocated internally in the KXMLGUIFactory for |
563 | // the menubar and the toolbars . This however implies that we | 564 | // the menubar and the toolbars . This however implies that we |
564 | // have to take care of deleting those widgets ourselves. For | 565 | // have to take care of deleting those widgets ourselves. For |
565 | // destruction this is no problem, but when rebuilding we have | 566 | // destruction this is no problem, but when rebuilding we have |
566 | // to take care of that (and we want to rebuild the GUI when | 567 | // to take care of that (and we want to rebuild the GUI when |
567 | // using stuff like the toolbar editor ). | 568 | // using stuff like the toolbar editor ). |
568 | // In addition we have to take care of not removing containers | 569 | // In addition we have to take care of not removing containers |
569 | // like popupmenus, defined in the XML document. | 570 | // like popupmenus, defined in the XML document. |
570 | // this code should probably go into a separate method in KMainWindow. | 571 | // this code should probably go into a separate method in KMainWindow. |
571 | // there's just one problem: I'm bad in finding names ;-) , so | 572 | // there's just one problem: I'm bad in finding names ;-) , so |
572 | // I skipped this ;-) | 573 | // I skipped this ;-) |
573 | 574 | ||
574 | QDomDocument doc = domDocument(); | 575 | QDomDocument doc = domDocument(); |
575 | 576 | ||
576 | QDomElement e = doc.documentElement().firstChild().toElement(); | 577 | QDomElement e = doc.documentElement().firstChild().toElement(); |
577 | for (; !e.isNull(); e = e.nextSibling().toElement() ) { | 578 | for (; !e.isNull(); e = e.nextSibling().toElement() ) { |
578 | if ( e.tagName().lower() == "toolbar" ) | 579 | if ( e.tagName().lower() == "toolbar" ) |
579 | factory_->resetContainer( e.attribute( "name" ) ); | 580 | factory_->resetContainer( e.attribute( "name" ) ); |
580 | else if ( e.tagName().lower() == "menubar" ) | 581 | else if ( e.tagName().lower() == "menubar" ) |
581 | factory_->resetContainer( e.tagName(), true ); | 582 | factory_->resetContainer( e.tagName(), true ); |
582 | } | 583 | } |
583 | 584 | ||
584 | conserveMemory(); | 585 | conserveMemory(); |
585 | } | 586 | } |
586 | */ | 587 | */ |
587 | setUpdatesEnabled( true ); | 588 | setUpdatesEnabled( true ); |
588 | updateGeometry(); | 589 | updateGeometry(); |
589 | } | 590 | } |
590 | 591 | ||
591 | void KMainWindow::saveMainWindowSettings(KConfig *config, const QString &configGroup) | 592 | void KMainWindow::saveMainWindowSettings(KConfig *config, const QString &configGroup) |
592 | { | 593 | { |
593 | kdDebug(200) << "KMainWindow::saveMainWindowSettings " << configGroup << endl; | 594 | kdDebug(200) << "KMainWindow::saveMainWindowSettings " << configGroup << endl; |
594 | //US QStrList entryList; | 595 | //US QStrList entryList; |
595 | QStringList entryList; | 596 | QStringList entryList; |
596 | QString oldGroup; | 597 | QString oldGroup; |
597 | 598 | ||
598 | if (!configGroup.isEmpty()) | 599 | if (!configGroup.isEmpty()) |
599 | { | 600 | { |
600 | oldGroup = config->group(); | 601 | oldGroup = config->group(); |
601 | config->setGroup(configGroup); | 602 | config->setGroup(configGroup); |
602 | } | 603 | } |
603 | 604 | ||
604 | // Called by session management - or if we want to save the window size anyway | 605 | // Called by session management - or if we want to save the window size anyway |
605 | if ( d->autoSaveWindowSize ) | 606 | if ( d->autoSaveWindowSize ) |
606 | saveWindowSize( config ); | 607 | saveWindowSize( config ); |
607 | 608 | ||
608 | QStatusBar* sb = internalStatusBar(); | 609 | QStatusBar* sb = internalStatusBar(); |
609 | if (sb) { | 610 | if (sb) { |
610 | entryList.clear(); | 611 | entryList.clear(); |
611 | if ( sb->isHidden() ) | 612 | if ( sb->isHidden() ) |
612 | entryList.append("Disabled"); | 613 | entryList.append("Disabled"); |
613 | else | 614 | else |
614 | entryList.append("Enabled"); | 615 | entryList.append("Enabled"); |
615 | 616 | ||
616 | if(sb->isHidden()) | 617 | if(sb->isHidden()) |
617 | //US config->writeEntry(QString::fromLatin1("StatusBar"), entryList, ';'); | 618 | //US config->writeEntry(QString::fromLatin1("StatusBar"), entryList, ';'); |
618 | config->writeEntry(QString::fromLatin1("StatusBar"), entryList); | 619 | config->writeEntry(QString::fromLatin1("StatusBar"), entryList); |
619 | else | 620 | else |
620 | config->deleteEntry(QString::fromLatin1("StatusBar")); | 621 | config->deleteEntry(QString::fromLatin1("StatusBar")); |
621 | } | 622 | } |
622 | 623 | ||
623 | QMenuBar* mb = internalMenuBar(); | 624 | QMenuBar* mb = internalMenuBar(); |
624 | if (mb) { | 625 | if (mb) { |
625 | entryList.clear(); | 626 | entryList.clear(); |
626 | if ( mb->isHidden() ) | 627 | if ( mb->isHidden() ) |
627 | entryList.append("Disabled"); | 628 | entryList.append("Disabled"); |
628 | else | 629 | else |
629 | entryList.append("Enabled"); | 630 | entryList.append("Enabled"); |
630 | 631 | ||
631 | // By default we don't hide. | 632 | // By default we don't hide. |
632 | if(mb->isHidden()) | 633 | if(mb->isHidden()) |
633 | //US config->writeEntry(QString::fromLatin1("MenuBar"), entryList, ';'); | 634 | //US config->writeEntry(QString::fromLatin1("MenuBar"), entryList, ';'); |
634 | config->writeEntry(QString::fromLatin1("MenuBar"), entryList); | 635 | config->writeEntry(QString::fromLatin1("MenuBar"), entryList); |
635 | else | 636 | else |
636 | config->deleteEntry(QString::fromLatin1("MenuBar")); | 637 | config->deleteEntry(QString::fromLatin1("MenuBar")); |
637 | } | 638 | } |
638 | 639 | ||
639 | int n = 1; // Toolbar counter. toolbars are counted from 1, | 640 | int n = 1; // Toolbar counter. toolbars are counted from 1, |
640 | KToolBar *toolbar = 0; | 641 | KToolBar *toolbar = 0; |
641 | QPtrListIterator<KToolBar> it( toolBarIterator() ); | 642 | QPtrListIterator<KToolBar> it( toolBarIterator() ); |
642 | while ( ( toolbar = it.current() ) ) { | 643 | while ( ( toolbar = it.current() ) ) { |
643 | ++it; | 644 | ++it; |
644 | QString group; | 645 | QString group; |
645 | if (!configGroup.isEmpty()) | 646 | if (!configGroup.isEmpty()) |
646 | { | 647 | { |
647 | // Give a number to the toolbar, but prefer a name if there is one, | 648 | // Give a number to the toolbar, but prefer a name if there is one, |
648 | // because there's no real guarantee on the ordering of toolbars | 649 | // because there's no real guarantee on the ordering of toolbars |
649 | group = (!::qstrcmp(toolbar->name(), "unnamed") ? QString::number(n) : QString(" ")+toolbar->name()); | 650 | group = (!::qstrcmp(toolbar->name(), "unnamed") ? QString::number(n) : QString(" ")+toolbar->name()); |
650 | group.prepend(" Toolbar"); | 651 | group.prepend(" Toolbar"); |
651 | group.prepend(configGroup); | 652 | group.prepend(configGroup); |
652 | } | 653 | } |
653 | toolbar->saveSettings(config, group); | 654 | toolbar->saveSettings(config, group); |
654 | n++; | 655 | n++; |
655 | } | 656 | } |
656 | if (!configGroup.isEmpty()) | 657 | if (!configGroup.isEmpty()) |
657 | config->setGroup(oldGroup); | 658 | config->setGroup(oldGroup); |
658 | } | 659 | } |
659 | 660 | ||
660 | bool KMainWindow::readPropertiesInternal( KConfig *config, int number ) | 661 | bool KMainWindow::readPropertiesInternal( KConfig *config, int number ) |
661 | { | 662 | { |
662 | if ( number == 1 ) | 663 | if ( number == 1 ) |
663 | readGlobalProperties( config ); | 664 | readGlobalProperties( config ); |
664 | 665 | ||
665 | // in order they are in toolbar list | 666 | // in order they are in toolbar list |
666 | QString s; | 667 | QString s; |
667 | s.setNum(number); | 668 | s.setNum(number); |
668 | s.prepend(QString::fromLatin1("WindowProperties")); | 669 | s.prepend(QString::fromLatin1("WindowProperties")); |
669 | 670 | ||
670 | config->setGroup(s); | 671 | config->setGroup(s); |
671 | 672 | ||
672 | // restore the object name (window role) | 673 | // restore the object name (window role) |
673 | if ( config->hasKey(QString::fromLatin1("ObjectName" )) ) | 674 | if ( config->hasKey(QString::fromLatin1("ObjectName" )) ) |
674 | setName( config->readEntry(QString::fromLatin1("ObjectName")).latin1()); // latin1 is right here | 675 | setName( config->readEntry(QString::fromLatin1("ObjectName")).latin1()); // latin1 is right here |
675 | 676 | ||
676 | applyMainWindowSettings(config); // Menubar, statusbar and toolbar settings. | 677 | applyMainWindowSettings(config); // Menubar, statusbar and toolbar settings. |
677 | 678 | ||
678 | s.setNum(number); | 679 | s.setNum(number); |
679 | config->setGroup(s); | 680 | config->setGroup(s); |
680 | readProperties(config); | 681 | readProperties(config); |
681 | return true; | 682 | return true; |
682 | } | 683 | } |
683 | 684 | ||
684 | void KMainWindow::applyMainWindowSettings(KConfig *config, const QString &configGroup) | 685 | void KMainWindow::applyMainWindowSettings(KConfig *config, const QString &configGroup) |
685 | { | 686 | { |
686 | kdDebug(200) << "KMainWindow::applyMainWindowSettings" << endl; | 687 | kdDebug(200) << "KMainWindow::applyMainWindowSettings" << endl; |
687 | QString entry; | 688 | QString entry; |
688 | //US QStrList entryList; | 689 | //US QStrList entryList; |
689 | QStringList entryList; | 690 | QStringList entryList; |
690 | int i = 0; // Number of entries in list | 691 | int i = 0; // Number of entries in list |
691 | 692 | ||
692 | if (!configGroup.isEmpty()) | 693 | if (!configGroup.isEmpty()) |
693 | config->setGroup(configGroup); | 694 | config->setGroup(configGroup); |
694 | 695 | ||
695 | restoreWindowSize(config); | 696 | restoreWindowSize(config); |
696 | 697 | ||
697 | QStatusBar* sb = internalStatusBar(); | 698 | QStatusBar* sb = internalStatusBar(); |
698 | if (sb) { | 699 | if (sb) { |
699 | entryList.clear(); | 700 | entryList.clear(); |
700 | //US i = config->readListEntry (QString::fromLatin1("StatusBar"), entryList, ';'); | 701 | //US i = config->readListEntry (QString::fromLatin1("StatusBar"), entryList, ';'); |
701 | entryList = config->readListEntry (QString::fromLatin1("StatusBar")); | 702 | entryList = config->readListEntry (QString::fromLatin1("StatusBar")); |
702 | entry = entryList.first(); | 703 | entry = entryList.first(); |
703 | if (entry == QString::fromLatin1("Disabled")) | 704 | if (entry == QString::fromLatin1("Disabled")) |
704 | sb->hide(); | 705 | sb->hide(); |
705 | else | 706 | else |
706 | sb->show(); | 707 | sb->show(); |
707 | if(d->showStatusBarAction) | 708 | if(d->showStatusBarAction) |
708 | d->showStatusBarAction->setChecked(!sb->isHidden()); | 709 | d->showStatusBarAction->setChecked(!sb->isHidden()); |
709 | } | 710 | } |
710 | 711 | ||
711 | QMenuBar* mb = internalMenuBar(); | 712 | QMenuBar* mb = internalMenuBar(); |
712 | if (mb) { | 713 | if (mb) { |
713 | entryList.clear(); | 714 | entryList.clear(); |
714 | //US i = config->readListEntry (QString::fromLatin1("MenuBar"), entryList, ';'); | 715 | //US i = config->readListEntry (QString::fromLatin1("MenuBar"), entryList, ';'); |
715 | entryList = config->readListEntry (QString::fromLatin1("MenuBar")); | 716 | entryList = config->readListEntry (QString::fromLatin1("MenuBar")); |
716 | entry = entryList.first(); | 717 | entry = entryList.first(); |
717 | if (entry==QString::fromLatin1("Disabled")) | 718 | if (entry==QString::fromLatin1("Disabled")) |
718 | { | 719 | { |
719 | mb->hide(); | 720 | mb->hide(); |
720 | } else | 721 | } else |
721 | { | 722 | { |
722 | mb->show(); | 723 | mb->show(); |
723 | } | 724 | } |
724 | } | 725 | } |
725 | 726 | ||
726 | int n = 1; // Toolbar counter. toolbars are counted from 1, | 727 | int n = 1; // Toolbar counter. toolbars are counted from 1, |
727 | KToolBar *toolbar; | 728 | KToolBar *toolbar; |
728 | QPtrListIterator<KToolBar> it( toolBarIterator() ); // must use own iterator | 729 | QPtrListIterator<KToolBar> it( toolBarIterator() ); // must use own iterator |
729 | 730 | ||
730 | for ( ; it.current(); ++it) { | 731 | for ( ; it.current(); ++it) { |
731 | toolbar= it.current(); | 732 | toolbar= it.current(); |
732 | QString group; | 733 | QString group; |
733 | if (!configGroup.isEmpty()) | 734 | if (!configGroup.isEmpty()) |
734 | { | 735 | { |
735 | // Give a number to the toolbar, but prefer a name if there is one, | 736 | // Give a number to the toolbar, but prefer a name if there is one, |
736 | // because there's no real guarantee on the ordering of toolbars | 737 | // because there's no real guarantee on the ordering of toolbars |
737 | group = (!::qstrcmp(toolbar->name(), "unnamed") ? QString::number(n) : QString(" ")+toolbar->name()); | 738 | group = (!::qstrcmp(toolbar->name(), "unnamed") ? QString::number(n) : QString(" ")+toolbar->name()); |
738 | group.prepend(" Toolbar"); | 739 | group.prepend(" Toolbar"); |
739 | group.prepend(configGroup); | 740 | group.prepend(configGroup); |
740 | } | 741 | } |
741 | toolbar->applySettings(config, group); | 742 | toolbar->applySettings(config, group); |
742 | n++; | 743 | n++; |
743 | } | 744 | } |
744 | 745 | ||
745 | finalizeGUI( true ); | 746 | finalizeGUI( true ); |
746 | } | 747 | } |
747 | 748 | ||
748 | void KMainWindow::finalizeGUI( bool force ) | 749 | void KMainWindow::finalizeGUI( bool force ) |
749 | { | 750 | { |
750 | //kdDebug(200) << "KMainWindow::finalizeGUI force=" << force << endl; | 751 | //kdDebug(200) << "KMainWindow::finalizeGUI force=" << force << endl; |
751 | // The whole reason for this is that moveToolBar relies on the indexes | 752 | // The whole reason for this is that moveToolBar relies on the indexes |
752 | // of the other toolbars, so in theory it should be called only once per | 753 | // of the other toolbars, so in theory it should be called only once per |
753 | // toolbar, but in increasing order of indexes. | 754 | // toolbar, but in increasing order of indexes. |
754 | // Since we can't do that immediately, we move them, and _then_ | 755 | // Since we can't do that immediately, we move them, and _then_ |
755 | // we call positionYourself again for each of them, but this time | 756 | // we call positionYourself again for each of them, but this time |
756 | // the toolbariterator should give them in the proper order. | 757 | // the toolbariterator should give them in the proper order. |
757 | // Both the XMLGUI and applySettings call this, hence "force" for the latter. | 758 | // Both the XMLGUI and applySettings call this, hence "force" for the latter. |
758 | QPtrListIterator<KToolBar> it( toolBarIterator() ); | 759 | QPtrListIterator<KToolBar> it( toolBarIterator() ); |
759 | for ( ; it.current() ; ++ it ) | 760 | for ( ; it.current() ; ++ it ) |
760 | it.current()->positionYourself( force ); | 761 | it.current()->positionYourself( force ); |
761 | 762 | ||
762 | d->settingsDirty = false; | 763 | d->settingsDirty = false; |
763 | } | 764 | } |
764 | 765 | ||
765 | void KMainWindow::saveWindowSize( KConfig * config ) const | 766 | void KMainWindow::saveWindowSize( KConfig * config ) const |
766 | { | 767 | { |
767 | /*US | 768 | /*US |
768 | int scnum = QApplication::desktop()->screenNumber(parentWidget()); | 769 | int scnum = QApplication::desktop()->screenNumber(parentWidget()); |
769 | QRect desk = QApplication::desktop()->screenGeometry(scnum); | 770 | QRect desk = QApplication::desktop()->screenGeometry(scnum); |
770 | */ | 771 | */ |
771 | QRect desk = KGlobalSettings::desktopGeometry(0); | 772 | QRect desk = KGlobalSettings::desktopGeometry(0); |
772 | 773 | ||
773 | QRect size( desk.width(), width(), desk.height(), height() ); | 774 | QRect size( desk.width(), width(), desk.height(), height() ); |
774 | if(size != d->defaultWindowSize){ | 775 | if(size != d->defaultWindowSize){ |
775 | config->writeEntry(QString::fromLatin1("Width %1").arg(desk.width()), width() ); | 776 | config->writeEntry(QString::fromLatin1("Width %1").arg(desk.width()), width() ); |
776 | config->writeEntry(QString::fromLatin1("Height %1").arg(desk.height()), height() ); | 777 | config->writeEntry(QString::fromLatin1("Height %1").arg(desk.height()), height() ); |
777 | } | 778 | } |
778 | else{ | 779 | else{ |
779 | config->deleteEntry(QString::fromLatin1("Width %1").arg(desk.width())); | 780 | config->deleteEntry(QString::fromLatin1("Width %1").arg(desk.width())); |
780 | config->deleteEntry(QString::fromLatin1("Height %1").arg(desk.height())); | 781 | config->deleteEntry(QString::fromLatin1("Height %1").arg(desk.height())); |
781 | } | 782 | } |
782 | } | 783 | } |
783 | 784 | ||
784 | void KMainWindow::restoreWindowSize( KConfig * config ) | 785 | void KMainWindow::restoreWindowSize( KConfig * config ) |
785 | { | 786 | { |
786 | if (d->care_about_geometry) { | 787 | if (d->care_about_geometry) { |
787 | parseGeometry(true); | 788 | parseGeometry(true); |
788 | } else { | 789 | } else { |
789 | // restore the size | 790 | // restore the size |
790 | /*US int scnum = QApplication::desktop()->screenNumber(parentWidget()); | 791 | /*US int scnum = QApplication::desktop()->screenNumber(parentWidget()); |
791 | QRect desk = QApplication::desktop()->screenGeometry(scnum); | 792 | QRect desk = QApplication::desktop()->screenGeometry(scnum); |
792 | */ | 793 | */ |
793 | QRect desk = KGlobalSettings::desktopGeometry(0); | 794 | QRect desk = KGlobalSettings::desktopGeometry(0); |
794 | 795 | ||
795 | QSize size( config->readNumEntry( QString::fromLatin1("Width %1").arg(desk.width()), 0 ), | 796 | QSize size( config->readNumEntry( QString::fromLatin1("Width %1").arg(desk.width()), 0 ), |
796 | config->readNumEntry( QString::fromLatin1("Height %1").arg(desk.height()), 0 ) ); | 797 | config->readNumEntry( QString::fromLatin1("Height %1").arg(desk.height()), 0 ) ); |
797 | if (size.isEmpty()) { | 798 | if (size.isEmpty()) { |
798 | // try the KDE 2.0 way | 799 | // try the KDE 2.0 way |
799 | size = QSize( config->readNumEntry( QString::fromLatin1("Width"), 0 ), | 800 | size = QSize( config->readNumEntry( QString::fromLatin1("Width"), 0 ), |
800 | config->readNumEntry( QString::fromLatin1("Height"), 0 ) ); | 801 | config->readNumEntry( QString::fromLatin1("Height"), 0 ) ); |
801 | if (!size.isEmpty()) { | 802 | if (!size.isEmpty()) { |
802 | // make sure the other resolutions don't get old settings | 803 | // make sure the other resolutions don't get old settings |
803 | config->writeEntry( QString::fromLatin1("Width"), 0 ); | 804 | config->writeEntry( QString::fromLatin1("Width"), 0 ); |
804 | config->writeEntry( QString::fromLatin1("Height"), 0 ); | 805 | config->writeEntry( QString::fromLatin1("Height"), 0 ); |
805 | } | 806 | } |
806 | } | 807 | } |
807 | if ( !size.isEmpty() ) | 808 | if ( !size.isEmpty() ) |
808 | resize( size ); | 809 | resize( size ); |
809 | } | 810 | } |
810 | } | 811 | } |
811 | 812 | ||
812 | bool KMainWindow::initialGeometrySet() const | 813 | bool KMainWindow::initialGeometrySet() const |
813 | { | 814 | { |
814 | return d->care_about_geometry; | 815 | return d->care_about_geometry; |
815 | } | 816 | } |
816 | 817 | ||
817 | void KMainWindow::ignoreInitialGeometry() | 818 | void KMainWindow::ignoreInitialGeometry() |
818 | { | 819 | { |
819 | d->care_about_geometry = false; | 820 | d->care_about_geometry = false; |
820 | } | 821 | } |
821 | 822 | ||
822 | void KMainWindow::setSettingsDirty() | 823 | void KMainWindow::setSettingsDirty() |
823 | { | 824 | { |
824 | //kdDebug(200) << "KMainWindow::setSettingsDirty" << endl; | 825 | //kdDebug(200) << "KMainWindow::setSettingsDirty" << endl; |
825 | d->settingsDirty = true; | 826 | d->settingsDirty = true; |
826 | if ( d->autoSaveSettings ) | 827 | if ( d->autoSaveSettings ) |
827 | { | 828 | { |
828 | // Use a timer to save "immediately" user-wise, but not too immediately | 829 | // Use a timer to save "immediately" user-wise, but not too immediately |
829 | // (to compress calls and save only once, in case of multiple changes) | 830 | // (to compress calls and save only once, in case of multiple changes) |
830 | if ( !d->settingsTimer ) | 831 | if ( !d->settingsTimer ) |
831 | { | 832 | { |
832 | d->settingsTimer = new QTimer( this ); | 833 | d->settingsTimer = new QTimer( this ); |
833 | connect( d->settingsTimer, SIGNAL( timeout() ), SLOT( saveAutoSaveSettings() ) ); | 834 | connect( d->settingsTimer, SIGNAL( timeout() ), SLOT( saveAutoSaveSettings() ) ); |
834 | } | 835 | } |
835 | d->settingsTimer->start( 500, true ); | 836 | d->settingsTimer->start( 500, true ); |
836 | } | 837 | } |
837 | } | 838 | } |
838 | 839 | ||
839 | bool KMainWindow::settingsDirty() const | 840 | bool KMainWindow::settingsDirty() const |
840 | { | 841 | { |
841 | return d->settingsDirty; | 842 | return d->settingsDirty; |
842 | } | 843 | } |
843 | 844 | ||
844 | QString KMainWindow::settingsGroup() const | 845 | QString KMainWindow::settingsGroup() const |
845 | { | 846 | { |
846 | return d->autoSaveGroup; | 847 | return d->autoSaveGroup; |
847 | } | 848 | } |
848 | 849 | ||
849 | void KMainWindow::resizeEvent( QResizeEvent * ) | 850 | void KMainWindow::resizeEvent( QResizeEvent * ) |
850 | { | 851 | { |
851 | if ( d->autoSaveWindowSize ) | 852 | if ( d->autoSaveWindowSize ) |
852 | setSettingsDirty(); | 853 | setSettingsDirty(); |
853 | } | 854 | } |
854 | 855 | ||
855 | bool KMainWindow::hasMenuBar() | 856 | bool KMainWindow::hasMenuBar() |
856 | { | 857 | { |
857 | return (internalMenuBar()); | 858 | return (internalMenuBar()); |
858 | } | 859 | } |
859 | 860 | ||
860 | //US KMenuBar *KMainWindow::menuBar() | 861 | //US KMenuBar *KMainWindow::menuBar() |
861 | QMenuBar *KMainWindow::menuBar() | 862 | QMenuBar *KMainWindow::menuBar() |
862 | { | 863 | { |
863 | //US KMenuBar * mb = internalMenuBar(); | 864 | //US KMenuBar * mb = internalMenuBar(); |
864 | QMenuBar * mb = internalMenuBar(); | 865 | QMenuBar * mb = internalMenuBar(); |
865 | if ( !mb ) { | 866 | if ( !mb ) { |
866 | //US mb = new KMenuBar( this ); | 867 | //US mb = new KMenuBar( this ); |
867 | mb = new QMenuBar( this ); | 868 | mb = new QMenuBar( this ); |
868 | // trigger a re-layout and trigger a call to the private | 869 | // trigger a re-layout and trigger a call to the private |
869 | // setMenuBar method. | 870 | // setMenuBar method. |
870 | QMainWindow::menuBar(); | 871 | QMainWindow::menuBar(); |
871 | } | 872 | } |
872 | return mb; | 873 | return mb; |
873 | } | 874 | } |
874 | 875 | ||
875 | //US KStatusBar *KMainWindow::statusBar() | 876 | //US KStatusBar *KMainWindow::statusBar() |
876 | QStatusBar *KMainWindow::statusBar() | 877 | QStatusBar *KMainWindow::statusBar() |
877 | { | 878 | { |
878 | //US KStatusBar * sb = internalStatusBar(); | 879 | //US KStatusBar * sb = internalStatusBar(); |
879 | QStatusBar * sb = internalStatusBar(); | 880 | QStatusBar * sb = internalStatusBar(); |
880 | if ( !sb ) { | 881 | if ( !sb ) { |
881 | //US sb = new KStatusBar( this ); | 882 | //US sb = new KStatusBar( this ); |
882 | sb = new QStatusBar( this ); | 883 | sb = new QStatusBar( this ); |
883 | // trigger a re-layout and trigger a call to the private | 884 | // trigger a re-layout and trigger a call to the private |
884 | // setStatusBar method. | 885 | // setStatusBar method. |
885 | QMainWindow::statusBar(); | 886 | QMainWindow::statusBar(); |
886 | } | 887 | } |
887 | return sb; | 888 | return sb; |
888 | } | 889 | } |
889 | 890 | ||
890 | void KMainWindow::shuttingDown() | 891 | void KMainWindow::shuttingDown() |
891 | { | 892 | { |
892 | // Needed for Qt <= 3.0.3 at least to prevent reentrancy | 893 | // Needed for Qt <= 3.0.3 at least to prevent reentrancy |
893 | // when queryExit() shows a dialog. Check before removing! | 894 | // when queryExit() shows a dialog. Check before removing! |
894 | static bool reentrancy_protection = false; | 895 | static bool reentrancy_protection = false; |
895 | if (!reentrancy_protection) | 896 | if (!reentrancy_protection) |
896 | { | 897 | { |
897 | reentrancy_protection = true; | 898 | reentrancy_protection = true; |
898 | // call the virtual queryExit | 899 | // call the virtual queryExit |
899 | queryExit(); | 900 | queryExit(); |
900 | reentrancy_protection = false; | 901 | reentrancy_protection = false; |
901 | } | 902 | } |
902 | 903 | ||
903 | } | 904 | } |
904 | 905 | ||
905 | //US KMenuBar *KMainWindow::internalMenuBar() | 906 | //US KMenuBar *KMainWindow::internalMenuBar() |
906 | QMenuBar *KMainWindow::internalMenuBar() | 907 | QMenuBar *KMainWindow::internalMenuBar() |
907 | { | 908 | { |
908 | //US QObjectList *l = queryList( "KMenuBar", 0, false, false ); | 909 | //US QObjectList *l = queryList( "KMenuBar", 0, false, false ); |
909 | QObjectList *l = queryList( "QMenuBar", 0, false, false ); | 910 | QObjectList *l = queryList( "QMenuBar", 0, false, false ); |
910 | if ( !l || !l->first() ) { | 911 | if ( !l || !l->first() ) { |
911 | delete l; | 912 | delete l; |
912 | return 0; | 913 | return 0; |
913 | } | 914 | } |
914 | 915 | ||
915 | //US KMenuBar *m = (KMenuBar*)l->first(); | 916 | //US KMenuBar *m = (KMenuBar*)l->first(); |
916 | QMenuBar *m = (QMenuBar*)l->first(); | 917 | QMenuBar *m = (QMenuBar*)l->first(); |
917 | delete l; | 918 | delete l; |
918 | return m; | 919 | return m; |
919 | } | 920 | } |
920 | 921 | ||
921 | //US KStatusBar *KMainWindow::internalStatusBar() | 922 | //US KStatusBar *KMainWindow::internalStatusBar() |
922 | QStatusBar *KMainWindow::internalStatusBar() | 923 | QStatusBar *KMainWindow::internalStatusBar() |
923 | { | 924 | { |
924 | //US QObjectList *l = queryList( "KStatusBar", 0, false, false ); | 925 | //US QObjectList *l = queryList( "KStatusBar", 0, false, false ); |
925 | QObjectList *l = queryList( "QStatusBar", 0, false, false ); | 926 | QObjectList *l = queryList( "QStatusBar", 0, false, false ); |
926 | if ( !l || !l->first() ) { | 927 | if ( !l || !l->first() ) { |
927 | delete l; | 928 | delete l; |
928 | return 0; | 929 | return 0; |
929 | } | 930 | } |
930 | 931 | ||
931 | //US KStatusBar *s = (KStatusBar*)l->first(); | 932 | //US KStatusBar *s = (KStatusBar*)l->first(); |
932 | QStatusBar *s = (QStatusBar*)l->first(); | 933 | QStatusBar *s = (QStatusBar*)l->first(); |
933 | delete l; | 934 | delete l; |
934 | return s; | 935 | return s; |
935 | } | 936 | } |
936 | 937 | ||
937 | void KMainWindow::childEvent( QChildEvent* e) | 938 | void KMainWindow::childEvent( QChildEvent* e) |
938 | { | 939 | { |
939 | QMainWindow::childEvent( e ); | 940 | QMainWindow::childEvent( e ); |
940 | } | 941 | } |
941 | 942 | ||
942 | void KMainWindow::paintEvent( QPaintEvent * ) | 943 | void KMainWindow::paintEvent( QPaintEvent * ) |
943 | { | 944 | { |
944 | // do nothing | 945 | // do nothing |
945 | } | 946 | } |
946 | 947 | ||
947 | QSize KMainWindow::sizeForCentralWidgetSize(QSize size) | 948 | QSize KMainWindow::sizeForCentralWidgetSize(QSize size) |
948 | { | 949 | { |
949 | KToolBar *tb = (KToolBar*)child( "mainToolBar", "KToolBar" ); | 950 | KToolBar *tb = (KToolBar*)child( "mainToolBar", "KToolBar" ); |
950 | if (tb && !tb->isHidden()) { | 951 | if (tb && !tb->isHidden()) { |
951 | switch( tb->barPos() ) | 952 | switch( tb->barPos() ) |
952 | { | 953 | { |
953 | case KToolBar::Top: | 954 | case KToolBar::Top: |
954 | case KToolBar::Bottom: | 955 | case KToolBar::Bottom: |
955 | size += QSize(0, tb->sizeHint().height()); | 956 | size += QSize(0, tb->sizeHint().height()); |
956 | break; | 957 | break; |
957 | 958 | ||
958 | case KToolBar::Left: | 959 | case KToolBar::Left: |
959 | case KToolBar::Right: | 960 | case KToolBar::Right: |
960 | size += QSize(toolBar()->sizeHint().width(), 0); | 961 | size += QSize(toolBar()->sizeHint().width(), 0); |
961 | break; | 962 | break; |
962 | 963 | ||
963 | case KToolBar::Flat: | 964 | case KToolBar::Flat: |
964 | //US size += QSize(0, 3+kapp->style().pixelMetric( QStyle::PM_DockWindowHandleExtent )); | 965 | //US size += QSize(0, 3+kapp->style().pixelMetric( QStyle::PM_DockWindowHandleExtent )); |
965 | size += QSize(0, tb->sizeHint().height()); | 966 | size += QSize(0, tb->sizeHint().height()); |
966 | break; | 967 | break; |
967 | 968 | ||
968 | default: | 969 | default: |
969 | break; | 970 | break; |
970 | } | 971 | } |
971 | } | 972 | } |
972 | //US KMenuBar *mb = menuBar(); | 973 | //US KMenuBar *mb = menuBar(); |
973 | QMenuBar *mb = menuBar(); | 974 | QMenuBar *mb = menuBar(); |
974 | if (!mb->isHidden()) { | 975 | if (!mb->isHidden()) { |
975 | size += QSize(0,mb->heightForWidth(size.width())); | 976 | size += QSize(0,mb->heightForWidth(size.width())); |
976 | /*US if (style().styleHint(QStyle::SH_MainWindow_SpaceBelowMenuBar, this)) | 977 | /*US if (style().styleHint(QStyle::SH_MainWindow_SpaceBelowMenuBar, this)) |
977 | size += QSize( 0, dockWindowsMovable() ? 1 : 2); | 978 | size += QSize( 0, dockWindowsMovable() ? 1 : 2); |
978 | */ | 979 | */ |
979 | size += QSize( 0, 2); | 980 | size += QSize( 0, 2); |
980 | } | 981 | } |
981 | QStatusBar *sb = internalStatusBar(); | 982 | QStatusBar *sb = internalStatusBar(); |
982 | if( sb && !sb->isHidden() ) | 983 | if( sb && !sb->isHidden() ) |
983 | size += QSize(0, sb->sizeHint().height()); | 984 | size += QSize(0, sb->sizeHint().height()); |
984 | 985 | ||
985 | return size; | 986 | return size; |
986 | } | 987 | } |
987 | 988 | ||
988 | // why do we support old gcc versions? using KXMLGUIBuilder::finalizeGUI; | 989 | // why do we support old gcc versions? using KXMLGUIBuilder::finalizeGUI; |
989 | void KMainWindow::finalizeGUI( KXMLGUIClient *client ) | 990 | void KMainWindow::finalizeGUI( KXMLGUIClient *client ) |
990 | { /*US KXMLGUIBuilder::finalizeGUI( client );*/ } | 991 | { /*US KXMLGUIBuilder::finalizeGUI( client );*/ } |
991 | 992 | ||
992 | void KMainWindow::virtual_hook( int id, void* data ) | 993 | void KMainWindow::virtual_hook( int id, void* data ) |
993 | { /*US KXMLGUIBuilder::virtual_hook( id, data );*/ | 994 | { /*US KXMLGUIBuilder::virtual_hook( id, data );*/ |
994 | KXMLGUIClient::virtual_hook( id, data ); } | 995 | KXMLGUIClient::virtual_hook( id, data ); } |
diff --git a/microkde/kdeui/kmainwindow.h b/microkde/kdeui/kmainwindow.h index e76e732..2aafb9d 100644 --- a/microkde/kdeui/kmainwindow.h +++ b/microkde/kdeui/kmainwindow.h | |||
@@ -1,776 +1,777 @@ | |||
1 | /* | 1 | /* |
2 | This file is part of the KDE libraries | 2 | This file is part of the KDE libraries |
3 | 3 | ||
4 | This library is free software; you can redistribute it and/or | 4 | This library is free software; you can redistribute it and/or |
5 | modify it under the terms of the GNU Library General Public | 5 | modify it under the terms of the GNU Library General Public |
6 | License version 2 as published by the Free Software Foundation. | 6 | License version 2 as published by the Free Software Foundation. |
7 | 7 | ||
8 | This library is distributed in the hope that it will be useful, | 8 | This library is distributed in the hope that it will be useful, |
9 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 9 | but WITHOUT ANY WARRANTY; without even the implied warranty of |
10 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 10 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
11 | Library General Public License for more details. | 11 | Library General Public License for more details. |
12 | 12 | ||
13 | You should have received a copy of the GNU Library General Public License | 13 | You should have received a copy of the GNU Library General Public License |
14 | along with this library; see the file COPYING.LIB. If not, write to | 14 | along with this library; see the file COPYING.LIB. If not, write to |
15 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | 15 | the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
16 | Boston, MA 02111-1307, USA. | 16 | Boston, MA 02111-1307, USA. |
17 | 17 | ||
18 | $Id$ | 18 | $Id$ |
19 | 19 | ||
20 | */ | 20 | */ |
21 | 21 | ||
22 | 22 | ||
23 | 23 | ||
24 | #ifndef KMAINWINDOW_H | 24 | #ifndef KMAINWINDOW_H |
25 | #define KMAINWINDOW_H | 25 | #define KMAINWINDOW_H |
26 | 26 | ||
27 | /*US | 27 | /*US |
28 | #include "kxmlguifactory.h" | 28 | #include "kxmlguifactory.h" |
29 | #include "kxmlguiclient.h" | 29 | #include "kxmlguiclient.h" |
30 | #include "kxmlguibuilder.h" | 30 | #include "kxmlguibuilder.h" |
31 | #include <qmetaobject.h> | 31 | #include <qmetaobject.h> |
32 | 32 | ||
33 | class KPopupMenu; | 33 | class KPopupMenu; |
34 | class KXMLGUIFactory; | 34 | class KXMLGUIFactory; |
35 | class KConfig; | 35 | class KConfig; |
36 | class KHelpMenu; | 36 | class KHelpMenu; |
37 | class KStatusBar; | 37 | class KStatusBar; |
38 | class QStatusBar; | 38 | class QStatusBar; |
39 | class KMenuBar; | 39 | class KMenuBar; |
40 | class KMWSessionManaged; | 40 | class KMWSessionManaged; |
41 | class KAccel; | 41 | class KAccel; |
42 | class KToolBarMenuAction; | 42 | class KToolBarMenuAction; |
43 | */ | 43 | */ |
44 | 44 | ||
45 | class QMenuBar; | 45 | class QMenuBar; |
46 | class QStatusBar; | 46 | class QStatusBar; |
47 | class KMainWindowPrivate; | 47 | class KMainWindowPrivate; |
48 | class KAction; | 48 | class KAction; |
49 | 49 | ||
50 | #include <ktoolbar.h> | 50 | #include <ktoolbar.h> |
51 | #include <ktoolbarhandler.h> | 51 | #include <ktoolbarhandler.h> |
52 | #include <kxmlguiclient.h> | 52 | #include <kxmlguiclient.h> |
53 | #include <qmainwindow.h> | 53 | #include <qmainwindow.h> |
54 | #include <qptrlist.h> | 54 | #include <qptrlist.h> |
55 | 55 | ||
56 | class KActionCollection; | 56 | class KActionCollection; |
57 | 57 | ||
58 | class KMainWindow : public QMainWindow, virtual public KXMLGUIClient | 58 | class KMainWindow : public QMainWindow, virtual public KXMLGUIClient |
59 | { | 59 | { |
60 | Q_OBJECT | 60 | Q_OBJECT |
61 | 61 | ||
62 | private: | 62 | private: |
63 | //US create private defaultconstructor | 63 | //US create private defaultconstructor |
64 | KMainWindow() {;}; | 64 | KMainWindow() {;}; |
65 | 65 | ||
66 | public: | 66 | |
67 | public: | 67 | public: |
68 | /** | 68 | /** |
69 | * Construct a main window. | 69 | * Construct a main window. |
70 | * | 70 | * |
71 | * @param parent The widget parent. This is usually 0 but it may also be the window | 71 | * @param parent The widget parent. This is usually 0 but it may also be the window |
72 | * group leader. In that case, the KMainWindow becomes sort of a | 72 | * group leader. In that case, the KMainWindow becomes sort of a |
73 | * secondary window. | 73 | * secondary window. |
74 | * | 74 | * |
75 | * @param name The object name. For session management and window management to work | 75 | * @param name The object name. For session management and window management to work |
76 | * properly, all main windows in the application should have a | 76 | * properly, all main windows in the application should have a |
77 | * different name. When passing 0 (the default), KMainWindow will create | 77 | * different name. When passing 0 (the default), KMainWindow will create |
78 | * a unique name, but it's recommended to explicitly pass a window name that will | 78 | * a unique name, but it's recommended to explicitly pass a window name that will |
79 | * also describe the type of the window. If there can be several windows of the same | 79 | * also describe the type of the window. If there can be several windows of the same |
80 | * type, append '#' (hash) to the name, and KMainWindow will append numbers to make | 80 | * type, append '#' (hash) to the name, and KMainWindow will append numbers to make |
81 | * the names unique. For example, for a mail client which has one main window showing | 81 | * the names unique. For example, for a mail client which has one main window showing |
82 | * the mails and folders, and which can also have one or more windows for composing | 82 | * the mails and folders, and which can also have one or more windows for composing |
83 | * mails, the name for the folders window should be e.g. "mainwindow" and | 83 | * mails, the name for the folders window should be e.g. "mainwindow" and |
84 | * for the composer windows "composer#". | 84 | * for the composer windows "composer#". |
85 | * | 85 | * |
86 | * @param f Specify the widget flags. The default is | 86 | * @param f Specify the widget flags. The default is |
87 | * WType_TopLevel and WDestructiveClose. TopLevel indicates that a | 87 | * WType_TopLevel and WDestructiveClose. TopLevel indicates that a |
88 | * main window is a toplevel window, regardless of whether it has a | 88 | * main window is a toplevel window, regardless of whether it has a |
89 | * parent or not. DestructiveClose indicates that a main window is | 89 | * parent or not. DestructiveClose indicates that a main window is |
90 | * automatically destroyed when its window is closed. Pass 0 if | 90 | * automatically destroyed when its window is closed. Pass 0 if |
91 | * you do not want this behavior. | 91 | * you do not want this behavior. |
92 | * | 92 | * |
93 | * KMainWindows must be created on the heap with 'new', like: | 93 | * KMainWindows must be created on the heap with 'new', like: |
94 | * <pre> KMainWindow *kmw = new KMainWindow (...</pre> | 94 | * <pre> KMainWindow *kmw = new KMainWindow (...</pre> |
95 | **/ | 95 | **/ |
96 | KMainWindow( QWidget* parent = 0, const char *name = 0, WFlags f = WType_TopLevel | WDestructiveClose ); | 96 | //LR remove WDestructiveClose |
97 | KMainWindow( QWidget* parent = 0, const char *name = 0, WFlags f = WType_TopLevel /*| WDestructiveClose*/ ); | ||
97 | 98 | ||
98 | 99 | ||
99 | /** | 100 | /** |
100 | * Destructor. | 101 | * Destructor. |
101 | * | 102 | * |
102 | * Will also destroy the toolbars, and menubar if | 103 | * Will also destroy the toolbars, and menubar if |
103 | * needed. | 104 | * needed. |
104 | */ | 105 | */ |
105 | virtual ~KMainWindow(); | 106 | virtual ~KMainWindow(); |
106 | 107 | ||
107 | /** | 108 | /** |
108 | * Retrieve the standard help menu. | 109 | * Retrieve the standard help menu. |
109 | * | 110 | * |
110 | * It contains entires for the | 111 | * It contains entires for the |
111 | * help system (activated by F1), an optional "What's This?" entry | 112 | * help system (activated by F1), an optional "What's This?" entry |
112 | * (activated by Shift F1), an application specific dialog box, | 113 | * (activated by Shift F1), an application specific dialog box, |
113 | * and an "About KDE" dialog box. | 114 | * and an "About KDE" dialog box. |
114 | * | 115 | * |
115 | * Example (adding a standard help menu to your application): | 116 | * Example (adding a standard help menu to your application): |
116 | * <pre> | 117 | * <pre> |
117 | * KPopupMenu *help = helpMenu( <myTextString> ); | 118 | * KPopupMenu *help = helpMenu( <myTextString> ); |
118 | * menuBar()->insertItem( i18n("&Help"), help ); | 119 | * menuBar()->insertItem( i18n("&Help"), help ); |
119 | * </pre> | 120 | * </pre> |
120 | * | 121 | * |
121 | * @param aboutAppText The string that is used in the application | 122 | * @param aboutAppText The string that is used in the application |
122 | * specific dialog box. If you leave this string empty the | 123 | * specific dialog box. If you leave this string empty the |
123 | * information in the global @ref KAboutData of the | 124 | * information in the global @ref KAboutData of the |
124 | * application will be used to make a standard dialog box. | 125 | * application will be used to make a standard dialog box. |
125 | * | 126 | * |
126 | * @param showWhatsThis Set this to false if you do not want to include | 127 | * @param showWhatsThis Set this to false if you do not want to include |
127 | * the "What's This" menu entry. | 128 | * the "What's This" menu entry. |
128 | * | 129 | * |
129 | * @return A standard help menu. | 130 | * @return A standard help menu. |
130 | */ | 131 | */ |
131 | //US KPopupMenu* helpMenu( const QString &aboutAppText = QString::null, | 132 | //US KPopupMenu* helpMenu( const QString &aboutAppText = QString::null, |
132 | //US bool showWhatsThis = TRUE ); | 133 | //US bool showWhatsThis = TRUE ); |
133 | 134 | ||
134 | /** | 135 | /** |
135 | * Returns the help menu. Creates a standard help menu if none exists yet. | 136 | * Returns the help menu. Creates a standard help menu if none exists yet. |
136 | * | 137 | * |
137 | * It contains entries for the | 138 | * It contains entries for the |
138 | * help system (activated by F1), an optional "What's This?" entry | 139 | * help system (activated by F1), an optional "What's This?" entry |
139 | * (activated by Shift F1), an application specific dialog box, | 140 | * (activated by Shift F1), an application specific dialog box, |
140 | * and an "About KDE" dialog box. You must create the application | 141 | * and an "About KDE" dialog box. You must create the application |
141 | * specific dialog box yourself. When the "About application" | 142 | * specific dialog box yourself. When the "About application" |
142 | * menu entry is activated, a signal will trigger the | 143 | * menu entry is activated, a signal will trigger the |
143 | * @ref showAboutApplication slot. See @ref showAboutApplication for more | 144 | * @ref showAboutApplication slot. See @ref showAboutApplication for more |
144 | * information. | 145 | * information. |
145 | * | 146 | * |
146 | * Example (adding a help menu to your application): | 147 | * Example (adding a help menu to your application): |
147 | * <pre> | 148 | * <pre> |
148 | * menuBar()->insertItem( i18n("&Help"), customHelpMenu() ); | 149 | * menuBar()->insertItem( i18n("&Help"), customHelpMenu() ); |
149 | * </pre> | 150 | * </pre> |
150 | * | 151 | * |
151 | * @param showWhatsThis Set this to @p false if you do not want to include | 152 | * @param showWhatsThis Set this to @p false if you do not want to include |
152 | * the "What's This" menu entry. | 153 | * the "What's This" menu entry. |
153 | * | 154 | * |
154 | * @return A standard help menu. | 155 | * @return A standard help menu. |
155 | */ | 156 | */ |
156 | //US KPopupMenu* customHelpMenu( bool showWhatsThis = TRUE ); | 157 | //US KPopupMenu* customHelpMenu( bool showWhatsThis = TRUE ); |
157 | 158 | ||
158 | /** | 159 | /** |
159 | * @sect Session Management | 160 | * @sect Session Management |
160 | * | 161 | * |
161 | * Try to restore the toplevel widget as defined by the number (1..X). | 162 | * Try to restore the toplevel widget as defined by the number (1..X). |
162 | * | 163 | * |
163 | * If the session did not contain so high a number, the configuration | 164 | * If the session did not contain so high a number, the configuration |
164 | * is not changed and @p false returned. | 165 | * is not changed and @p false returned. |
165 | * | 166 | * |
166 | * That means clients could simply do the following: | 167 | * That means clients could simply do the following: |
167 | * <pre> | 168 | * <pre> |
168 | * if (kapp->isRestored()){ | 169 | * if (kapp->isRestored()){ |
169 | * int n = 1; | 170 | * int n = 1; |
170 | * while (KMainWindow::canBeRestored(n)){ | 171 | * while (KMainWindow::canBeRestored(n)){ |
171 | * (new childMW)->restore(n); | 172 | * (new childMW)->restore(n); |
172 | * n++; | 173 | * n++; |
173 | * } | 174 | * } |
174 | * } else { | 175 | * } else { |
175 | * // create default application as usual | 176 | * // create default application as usual |
176 | * } | 177 | * } |
177 | * </pre> | 178 | * </pre> |
178 | * Note that @ref QWidget::show() is called implicitly in restore. | 179 | * Note that @ref QWidget::show() is called implicitly in restore. |
179 | * | 180 | * |
180 | * With this you can easily restore all toplevel windows of your | 181 | * With this you can easily restore all toplevel windows of your |
181 | * application. | 182 | * application. |
182 | * | 183 | * |
183 | * If your application uses different kinds of toplevel | 184 | * If your application uses different kinds of toplevel |
184 | * windows, then you can use @ref KMainWindow::classNameOfToplevel(n) | 185 | * windows, then you can use @ref KMainWindow::classNameOfToplevel(n) |
185 | * to determine the exact type before calling the childMW | 186 | * to determine the exact type before calling the childMW |
186 | * constructor in the example from above. | 187 | * constructor in the example from above. |
187 | * | 188 | * |
188 | * If your client has only one kind of toplevel widgets (which | 189 | * If your client has only one kind of toplevel widgets (which |
189 | * should be pretty usual) then you should use the RESTORE-macro | 190 | * should be pretty usual) then you should use the RESTORE-macro |
190 | * for backwards compatibility with 3.1 and 3.0 branches: | 191 | * for backwards compatibility with 3.1 and 3.0 branches: |
191 | * | 192 | * |
192 | * <pre> | 193 | * <pre> |
193 | * if (kapp->isRestored()) | 194 | * if (kapp->isRestored()) |
194 | * RESTORE(childMW) | 195 | * RESTORE(childMW) |
195 | * else { | 196 | * else { |
196 | * // create default application as usual | 197 | * // create default application as usual |
197 | * } | 198 | * } |
198 | * </pre> | 199 | * </pre> |
199 | * | 200 | * |
200 | * The macro expands to the term above but is easier to use and | 201 | * The macro expands to the term above but is easier to use and |
201 | * less code to write. | 202 | * less code to write. |
202 | * | 203 | * |
203 | * For new code or if you have more than one kind of toplevel | 204 | * For new code or if you have more than one kind of toplevel |
204 | * widget (each derived from @ref KMainWindow, of course), you can | 205 | * widget (each derived from @ref KMainWindow, of course), you can |
205 | * use the templated @ref kRestoreMainWindows global functions: | 206 | * use the templated @ref kRestoreMainWindows global functions: |
206 | * | 207 | * |
207 | * <pre> | 208 | * <pre> |
208 | * if (kapp->isRestored()) | 209 | * if (kapp->isRestored()) |
209 | * kRestoreMainWindows< childMW1, childMW2, childMW3 >(); | 210 | * kRestoreMainWindows< childMW1, childMW2, childMW3 >(); |
210 | * else { | 211 | * else { |
211 | * // create default application as usual | 212 | * // create default application as usual |
212 | * } | 213 | * } |
213 | * </pre> | 214 | * </pre> |
214 | * | 215 | * |
215 | * Currently, these functions are provided for up to three | 216 | * Currently, these functions are provided for up to three |
216 | * template arguments. If you need more, tell us. To help you in | 217 | * template arguments. If you need more, tell us. To help you in |
217 | * deciding whether or not you can use @ref kRestoreMainWindows, a | 218 | * deciding whether or not you can use @ref kRestoreMainWindows, a |
218 | * define KDE_RESTORE_MAIN_WINDOWS_NUM_TEMPLATE_ARGS is provided. | 219 | * define KDE_RESTORE_MAIN_WINDOWS_NUM_TEMPLATE_ARGS is provided. |
219 | * | 220 | * |
220 | * @see restore() | 221 | * @see restore() |
221 | * @see classNameOfToplevel() | 222 | * @see classNameOfToplevel() |
222 | * | 223 | * |
223 | **/ | 224 | **/ |
224 | static bool canBeRestored( int number ); | 225 | static bool canBeRestored( int number ); |
225 | 226 | ||
226 | /** | 227 | /** |
227 | * Returns the @ref className() of the @p number of the toplevel window which | 228 | * Returns the @ref className() of the @p number of the toplevel window which |
228 | * should be restored. | 229 | * should be restored. |
229 | * | 230 | * |
230 | * This is only useful if your application uses | 231 | * This is only useful if your application uses |
231 | * different kinds of toplevel windows. | 232 | * different kinds of toplevel windows. |
232 | */ | 233 | */ |
233 | static const QString classNameOfToplevel( int number ); | 234 | static const QString classNameOfToplevel( int number ); |
234 | 235 | ||
235 | /** | 236 | /** |
236 | * Restore the session specified by @p number. | 237 | * Restore the session specified by @p number. |
237 | * | 238 | * |
238 | * Returns @p false if this | 239 | * Returns @p false if this |
239 | * fails, otherwise returns @p true and shows the window. | 240 | * fails, otherwise returns @p true and shows the window. |
240 | * You should call @ref canBeRestored() first. | 241 | * You should call @ref canBeRestored() first. |
241 | * If @p show is true (default), this widget will be shown automatically. | 242 | * If @p show is true (default), this widget will be shown automatically. |
242 | */ | 243 | */ |
243 | bool restore( int number, bool show = TRUE ); | 244 | bool restore( int number, bool show = TRUE ); |
244 | 245 | ||
245 | //US virtual KXMLGUIFactory *guiFactory(); | 246 | //US virtual KXMLGUIFactory *guiFactory(); |
246 | 247 | ||
247 | /** | 248 | /** |
248 | * Create a GUI given a local XML file. | 249 | * Create a GUI given a local XML file. |
249 | * | 250 | * |
250 | * If @p xmlfile is NULL, | 251 | * If @p xmlfile is NULL, |
251 | * then it will try to construct a local XML filename like | 252 | * then it will try to construct a local XML filename like |
252 | * appnameui.rc where 'appname' is your app's name. If that file | 253 | * appnameui.rc where 'appname' is your app's name. If that file |
253 | * does not exist, then the XML UI code will only use the global | 254 | * does not exist, then the XML UI code will only use the global |
254 | * (standard) XML file for the layout purposes. | 255 | * (standard) XML file for the layout purposes. |
255 | * | 256 | * |
256 | * Note that when passing true for the conserveMemory argument subsequent | 257 | * Note that when passing true for the conserveMemory argument subsequent |
257 | * calls to guiFactory()->addClient/removeClient may not work as expected. | 258 | * calls to guiFactory()->addClient/removeClient may not work as expected. |
258 | * Also retrieving references to containers like popup menus or toolbars using | 259 | * Also retrieving references to containers like popup menus or toolbars using |
259 | * the container method will not work. | 260 | * the container method will not work. |
260 | * | 261 | * |
261 | * @param xmlfile The local xmlfile (relative or absolute) | 262 | * @param xmlfile The local xmlfile (relative or absolute) |
262 | * @param _conserveMemory Specify whether createGUI() should call | 263 | * @param _conserveMemory Specify whether createGUI() should call |
263 | * @ref KXMLGuiClient::conserveMemory() to free all memory | 264 | * @ref KXMLGuiClient::conserveMemory() to free all memory |
264 | * allocated by the @ref QDomDocument and by the KXMLGUIFactory. | 265 | * allocated by the @ref QDomDocument and by the KXMLGUIFactory. |
265 | */ | 266 | */ |
266 | void createGUI( const QString &xmlfile = QString::null, bool _conserveMemory = TRUE ); | 267 | void createGUI( const QString &xmlfile = QString::null, bool _conserveMemory = TRUE ); |
267 | 268 | ||
268 | /** | 269 | /** |
269 | * Enables the build of a standard help menu when calling createGUI(). | 270 | * Enables the build of a standard help menu when calling createGUI(). |
270 | * | 271 | * |
271 | * The default behavior is to build one, you must call this function | 272 | * The default behavior is to build one, you must call this function |
272 | * to disable it | 273 | * to disable it |
273 | */ | 274 | */ |
274 | void setHelpMenuEnabled(bool showHelpMenu = true); | 275 | void setHelpMenuEnabled(bool showHelpMenu = true); |
275 | 276 | ||
276 | /** | 277 | /** |
277 | * Return @p true when the help menu is enabled | 278 | * Return @p true when the help menu is enabled |
278 | */ | 279 | */ |
279 | bool isHelpMenuEnabled(); | 280 | bool isHelpMenuEnabled(); |
280 | 281 | ||
281 | 282 | ||
282 | /** | 283 | /** |
283 | * Returns true, if there is a menubar | 284 | * Returns true, if there is a menubar |
284 | * @since 3.1 | 285 | * @since 3.1 |
285 | */ | 286 | */ |
286 | bool hasMenuBar(); | 287 | bool hasMenuBar(); |
287 | 288 | ||
288 | /** | 289 | /** |
289 | * Returns a pointer to the menu bar. | 290 | * Returns a pointer to the menu bar. |
290 | * | 291 | * |
291 | * If there is no menu bar yet one will be created. | 292 | * If there is no menu bar yet one will be created. |
292 | **/ | 293 | **/ |
293 | //US KMenuBar *menuBar(); | 294 | //US KMenuBar *menuBar(); |
294 | QMenuBar *menuBar(); | 295 | QMenuBar *menuBar(); |
295 | 296 | ||
296 | /** | 297 | /** |
297 | * Returns a pointer to the status bar. | 298 | * Returns a pointer to the status bar. |
298 | * | 299 | * |
299 | * If there is no | 300 | * If there is no |
300 | * status bar yet one will be created. | 301 | * status bar yet one will be created. |
301 | */ | 302 | */ |
302 | //US KStatusBar *statusBar(); | 303 | //US KStatusBar *statusBar(); |
303 | QStatusBar *statusBar(); | 304 | QStatusBar *statusBar(); |
304 | 305 | ||
305 | /** | 306 | /** |
306 | * List of members of KMainWindow class. | 307 | * List of members of KMainWindow class. |
307 | */ | 308 | */ |
308 | //US static QPtrList<KMainWindow>* memberList; | 309 | //US static QPtrList<KMainWindow>* memberList; |
309 | 310 | ||
310 | /** | 311 | /** |
311 | * Returns a pointer to the toolbar with the specified name. | 312 | * Returns a pointer to the toolbar with the specified name. |
312 | * This refers to toolbars created dynamically from the XML UI | 313 | * This refers to toolbars created dynamically from the XML UI |
313 | * framework. If the toolbar does not exist one will be created. | 314 | * framework. If the toolbar does not exist one will be created. |
314 | * | 315 | * |
315 | * @param name The internal name of the toolbar. If no name is | 316 | * @param name The internal name of the toolbar. If no name is |
316 | * specified "mainToolBar" is assumed. | 317 | * specified "mainToolBar" is assumed. |
317 | * | 318 | * |
318 | * @return A pointer to the toolbar | 319 | * @return A pointer to the toolbar |
319 | **/ | 320 | **/ |
320 | KToolBar *toolBar( const char *name=0 ); | 321 | KToolBar *toolBar( const char *name=0 ); |
321 | // method for getting rid of KDE-Crap | 322 | // method for getting rid of KDE-Crap |
322 | QToolBar *tBar( ); | 323 | QToolBar *tBar( ); |
323 | 324 | ||
324 | /** | 325 | /** |
325 | * @return An iterator over the list of all toolbars for this window. | 326 | * @return An iterator over the list of all toolbars for this window. |
326 | */ | 327 | */ |
327 | QPtrListIterator<KToolBar> toolBarIterator(); | 328 | QPtrListIterator<KToolBar> toolBarIterator(); |
328 | 329 | ||
329 | /** | 330 | /** |
330 | * @return A KAccel instance bound to this mainwindow. Used automatically | 331 | * @return A KAccel instance bound to this mainwindow. Used automatically |
331 | * by KAction to make keybindings work in all cases. | 332 | * by KAction to make keybindings work in all cases. |
332 | */ | 333 | */ |
333 | KAccel *accel(); | 334 | KAccel *accel(); |
334 | 335 | ||
335 | void setFrameBorderWidth( int ) {} | 336 | void setFrameBorderWidth( int ) {} |
336 | 337 | ||
337 | /** | 338 | /** |
338 | * Call this to enable "auto-save" of toolbar/menubar/statusbar settings | 339 | * Call this to enable "auto-save" of toolbar/menubar/statusbar settings |
339 | * (and optionally window size). | 340 | * (and optionally window size). |
340 | * If the *bars were moved around/shown/hidden when the window is closed, | 341 | * If the *bars were moved around/shown/hidden when the window is closed, |
341 | * saveMainWindowSettings( KGlobal::config(), groupName ) will be called. | 342 | * saveMainWindowSettings( KGlobal::config(), groupName ) will be called. |
342 | * | 343 | * |
343 | * @param groupName a name that identifies this "type of window". | 344 | * @param groupName a name that identifies this "type of window". |
344 | * You can have several types of window in the same application. | 345 | * You can have several types of window in the same application. |
345 | * | 346 | * |
346 | * @param saveWindowSize set it to true to include the window size | 347 | * @param saveWindowSize set it to true to include the window size |
347 | * when saving. | 348 | * when saving. |
348 | * | 349 | * |
349 | * Typically, you will call setAutoSaveSettings() in your | 350 | * Typically, you will call setAutoSaveSettings() in your |
350 | * KMainWindow-inherited class constructor, and it will take care | 351 | * KMainWindow-inherited class constructor, and it will take care |
351 | * of restoring and saving automatically. Make sure you call this | 352 | * of restoring and saving automatically. Make sure you call this |
352 | * _after all_ your *bars have been created. | 353 | * _after all_ your *bars have been created. |
353 | */ | 354 | */ |
354 | void setAutoSaveSettings( const QString & groupName = QString::fromLatin1("MainWindow"), | 355 | void setAutoSaveSettings( const QString & groupName = QString::fromLatin1("MainWindow"), |
355 | bool saveWindowSize = true ); | 356 | bool saveWindowSize = true ); |
356 | 357 | ||
357 | /** | 358 | /** |
358 | * Disable the auto-save-settings feature. | 359 | * Disable the auto-save-settings feature. |
359 | * You don't normally need to call this, ever. | 360 | * You don't normally need to call this, ever. |
360 | */ | 361 | */ |
361 | void resetAutoSaveSettings(); | 362 | void resetAutoSaveSettings(); |
362 | 363 | ||
363 | /** | 364 | /** |
364 | * @return the current autosave setting, i.e. true if setAutoSaveSettings() was called, | 365 | * @return the current autosave setting, i.e. true if setAutoSaveSettings() was called, |
365 | * false by default or if resetAutoSaveSettings() was called. | 366 | * false by default or if resetAutoSaveSettings() was called. |
366 | * @since 3.1 | 367 | * @since 3.1 |
367 | */ | 368 | */ |
368 | bool autoSaveSettings() const; | 369 | bool autoSaveSettings() const; |
369 | 370 | ||
370 | /** | 371 | /** |
371 | * @return the group used for setting-autosaving. | 372 | * @return the group used for setting-autosaving. |
372 | * Only meaningful if setAutoSaveSettings() was called. | 373 | * Only meaningful if setAutoSaveSettings() was called. |
373 | * This can be useful for forcing a save or an apply, e.g. before and after | 374 | * This can be useful for forcing a save or an apply, e.g. before and after |
374 | * using KEditToolbar. | 375 | * using KEditToolbar. |
375 | * @since 3.1 | 376 | * @since 3.1 |
376 | */ | 377 | */ |
377 | QString autoSaveGroup() const; | 378 | QString autoSaveGroup() const; |
378 | 379 | ||
379 | /** | 380 | /** |
380 | * Read settings for statusbar, menubar and toolbar from their respective | 381 | * Read settings for statusbar, menubar and toolbar from their respective |
381 | * groups in the config file and apply them. | 382 | * groups in the config file and apply them. |
382 | * | 383 | * |
383 | * @param config Config file to read the settings from. | 384 | * @param config Config file to read the settings from. |
384 | * @param groupName Group name to use. If not specified, the last used | 385 | * @param groupName Group name to use. If not specified, the last used |
385 | * group name is used. | 386 | * group name is used. |
386 | */ | 387 | */ |
387 | void applyMainWindowSettings(KConfig *config, const QString &groupName = QString::null); | 388 | void applyMainWindowSettings(KConfig *config, const QString &groupName = QString::null); |
388 | 389 | ||
389 | /** | 390 | /** |
390 | * Save settings for statusbar, menubar and toolbar to their respective | 391 | * Save settings for statusbar, menubar and toolbar to their respective |
391 | * groups in the config file @p config. | 392 | * groups in the config file @p config. |
392 | * | 393 | * |
393 | * @param config Config file to save the settings to. | 394 | * @param config Config file to save the settings to. |
394 | * @param groupName Group name to use. If not specified, the last used | 395 | * @param groupName Group name to use. If not specified, the last used |
395 | * group name is used | 396 | * group name is used |
396 | */ | 397 | */ |
397 | void saveMainWindowSettings(KConfig *config, const QString &groupName = QString::null); | 398 | void saveMainWindowSettings(KConfig *config, const QString &groupName = QString::null); |
398 | 399 | ||
399 | /** | 400 | /** |
400 | * Sets whether KMainWindow should provide a menu that allows showing/hiding | 401 | * Sets whether KMainWindow should provide a menu that allows showing/hiding |
401 | * the available toolbars ( using @ref KToggleToolBarAction ) . In case there | 402 | * the available toolbars ( using @ref KToggleToolBarAction ) . In case there |
402 | * is only one toolbar configured a simple 'Show <toolbar name here>' menu item | 403 | * is only one toolbar configured a simple 'Show <toolbar name here>' menu item |
403 | * is shown. | 404 | * is shown. |
404 | * | 405 | * |
405 | * The menu / menu item is implemented using xmlgui. It will be inserted in your | 406 | * The menu / menu item is implemented using xmlgui. It will be inserted in your |
406 | * menu structure in the 'Settings' menu. | 407 | * menu structure in the 'Settings' menu. |
407 | * | 408 | * |
408 | * If your application uses a non-standard xmlgui resource file then you can | 409 | * If your application uses a non-standard xmlgui resource file then you can |
409 | * specify the exact position of the menu / menu item by adding a | 410 | * specify the exact position of the menu / menu item by adding a |
410 | * <Merge name="StandardToolBarMenuHandler" /> | 411 | * <Merge name="StandardToolBarMenuHandler" /> |
411 | * line to the settings menu section of your resource file ( usually appname.rc ). | 412 | * line to the settings menu section of your resource file ( usually appname.rc ). |
412 | * | 413 | * |
413 | * Note that you should enable this feature before calling createGUI() ( or similar ) . | 414 | * Note that you should enable this feature before calling createGUI() ( or similar ) . |
414 | * You enable/disable it anytime if you pass false to the conserveMemory argument of createGUI. | 415 | * You enable/disable it anytime if you pass false to the conserveMemory argument of createGUI. |
415 | * @since 3.1 | 416 | * @since 3.1 |
416 | */ | 417 | */ |
417 | void setStandardToolBarMenuEnabled( bool enable ); | 418 | void setStandardToolBarMenuEnabled( bool enable ); |
418 | /// @since 3.1 | 419 | /// @since 3.1 |
419 | bool isStandardToolBarMenuEnabled() const; | 420 | bool isStandardToolBarMenuEnabled() const; |
420 | 421 | ||
421 | 422 | ||
422 | /** | 423 | /** |
423 | * Sets whether KMainWindow should provide a menu that allows showing/hiding | 424 | * Sets whether KMainWindow should provide a menu that allows showing/hiding |
424 | * of the statusbar ( using @ref KToggleStatusBarAction ). | 425 | * of the statusbar ( using @ref KToggleStatusBarAction ). |
425 | * | 426 | * |
426 | * The menu / menu item is implemented using xmlgui. It will be inserted | 427 | * The menu / menu item is implemented using xmlgui. It will be inserted |
427 | * in your menu structure in the 'Settings' menu. | 428 | * in your menu structure in the 'Settings' menu. |
428 | * | 429 | * |
429 | * Note that you should enable this feature before calling createGUI() | 430 | * Note that you should enable this feature before calling createGUI() |
430 | * ( or similar ). | 431 | * ( or similar ). |
431 | * | 432 | * |
432 | * If an application maintains the action on its own (i.e. never calls | 433 | * If an application maintains the action on its own (i.e. never calls |
433 | * this function) a connection needs to be made to let KMainWindow | 434 | * this function) a connection needs to be made to let KMainWindow |
434 | * know when that status (hidden/shown) of the statusbar has changed. | 435 | * know when that status (hidden/shown) of the statusbar has changed. |
435 | * For example: | 436 | * For example: |
436 | * connect(action, SIGNAL(activated()), | 437 | * connect(action, SIGNAL(activated()), |
437 | * kmainwindow, SLOT(setSettingsDirty())); | 438 | * kmainwindow, SLOT(setSettingsDirty())); |
438 | * Otherwise the status (hidden/show) of the statusbar might not be saved | 439 | * Otherwise the status (hidden/show) of the statusbar might not be saved |
439 | * by KMainWindow. | 440 | * by KMainWindow. |
440 | * @since 3.2 | 441 | * @since 3.2 |
441 | */ | 442 | */ |
442 | void createStandardStatusBarAction(); | 443 | void createStandardStatusBarAction(); |
443 | 444 | ||
444 | 445 | ||
445 | /** | 446 | /** |
446 | * Returns a pointer to the mainwindows action responsible for the toolbars menu | 447 | * Returns a pointer to the mainwindows action responsible for the toolbars menu |
447 | * @since 3.1 | 448 | * @since 3.1 |
448 | */ | 449 | */ |
449 | KAction *toolBarMenuAction(); | 450 | KAction *toolBarMenuAction(); |
450 | 451 | ||
451 | // why do we support old gcc versions? using KXMLGUIBuilder::finalizeGUI; | 452 | // why do we support old gcc versions? using KXMLGUIBuilder::finalizeGUI; |
452 | /// @since 3.1 | 453 | /// @since 3.1 |
453 | virtual void finalizeGUI( KXMLGUIClient *client ); | 454 | virtual void finalizeGUI( KXMLGUIClient *client ); |
454 | 455 | ||
455 | /** | 456 | /** |
456 | * @internal | 457 | * @internal |
457 | */ | 458 | */ |
458 | void finalizeGUI( bool force ); | 459 | void finalizeGUI( bool force ); |
459 | 460 | ||
460 | /** | 461 | /** |
461 | * @return true if a -geometry argument was given on the command line, | 462 | * @return true if a -geometry argument was given on the command line, |
462 | * and this is the first window created (the one on which this option applies) | 463 | * and this is the first window created (the one on which this option applies) |
463 | */ | 464 | */ |
464 | bool initialGeometrySet() const; | 465 | bool initialGeometrySet() const; |
465 | 466 | ||
466 | /** | 467 | /** |
467 | * @internal | 468 | * @internal |
468 | * Used from Konqueror when reusing the main window. | 469 | * Used from Konqueror when reusing the main window. |
469 | */ | 470 | */ |
470 | void ignoreInitialGeometry(); | 471 | void ignoreInitialGeometry(); |
471 | 472 | ||
472 | /** | 473 | /** |
473 | * @return the size the mainwindow should have so that the central | 474 | * @return the size the mainwindow should have so that the central |
474 | * widget will be of @p size. | 475 | * widget will be of @p size. |
475 | */ | 476 | */ |
476 | QSize sizeForCentralWidgetSize(QSize size); | 477 | QSize sizeForCentralWidgetSize(QSize size); |
477 | 478 | ||
478 | public slots: | 479 | public slots: |
479 | /** | 480 | /** |
480 | * Makes a KDE compliant caption. | 481 | * Makes a KDE compliant caption. |
481 | * | 482 | * |
482 | * @param caption Your caption. @em Do @em not include the application name | 483 | * @param caption Your caption. @em Do @em not include the application name |
483 | * in this string. It will be added automatically according to the KDE | 484 | * in this string. It will be added automatically according to the KDE |
484 | * standard. | 485 | * standard. |
485 | */ | 486 | */ |
486 | virtual void setCaption( const QString &caption ); | 487 | virtual void setCaption( const QString &caption ); |
487 | /** | 488 | /** |
488 | * Makes a KDE compliant caption. | 489 | * Makes a KDE compliant caption. |
489 | * | 490 | * |
490 | * @param caption Your caption. @em Do @em not include the application name | 491 | * @param caption Your caption. @em Do @em not include the application name |
491 | * in this string. It will be added automatically according to the KDE | 492 | * in this string. It will be added automatically according to the KDE |
492 | * standard. | 493 | * standard. |
493 | * @param modified Specify whether the document is modified. This displays | 494 | * @param modified Specify whether the document is modified. This displays |
494 | * an additional sign in the title bar, usually "**". | 495 | * an additional sign in the title bar, usually "**". |
495 | */ | 496 | */ |
496 | virtual void setCaption( const QString &caption, bool modified ); | 497 | virtual void setCaption( const QString &caption, bool modified ); |
497 | 498 | ||
498 | /** | 499 | /** |
499 | * Make a plain caption without any modifications. | 500 | * Make a plain caption without any modifications. |
500 | * | 501 | * |
501 | * @param caption Your caption. This is the string that will be | 502 | * @param caption Your caption. This is the string that will be |
502 | * displayed in the window title. | 503 | * displayed in the window title. |
503 | */ | 504 | */ |
504 | virtual void setPlainCaption( const QString &caption ); | 505 | virtual void setPlainCaption( const QString &caption ); |
505 | 506 | ||
506 | /** | 507 | /** |
507 | * Open the help page for the application. | 508 | * Open the help page for the application. |
508 | * | 509 | * |
509 | * The application name is | 510 | * The application name is |
510 | * used as a key to determine what to display and the system will attempt | 511 | * used as a key to determine what to display and the system will attempt |
511 | * to open <appName>/index.html. | 512 | * to open <appName>/index.html. |
512 | * | 513 | * |
513 | * This method is intended for use by a help button in the toolbar or | 514 | * This method is intended for use by a help button in the toolbar or |
514 | * components outside the regular help menu. Use @ref helpMenu() when you | 515 | * components outside the regular help menu. Use @ref helpMenu() when you |
515 | * want to provide access to the help system from the help menu. | 516 | * want to provide access to the help system from the help menu. |
516 | * | 517 | * |
517 | * Example (adding a help button to the first toolbar): | 518 | * Example (adding a help button to the first toolbar): |
518 | * | 519 | * |
519 | * <pre> | 520 | * <pre> |
520 | * KIconLoader &loader = *KGlobal::iconLoader(); | 521 | * KIconLoader &loader = *KGlobal::iconLoader(); |
521 | * QPixmap pixmap = loader.loadIcon( "help" ); | 522 | * QPixmap pixmap = loader.loadIcon( "help" ); |
522 | * toolBar(0)->insertButton( pixmap, 0, SIGNAL(clicked()), | 523 | * toolBar(0)->insertButton( pixmap, 0, SIGNAL(clicked()), |
523 | * this, SLOT(appHelpActivated()), true, i18n("Help") ); | 524 | * this, SLOT(appHelpActivated()), true, i18n("Help") ); |
524 | * </pre> | 525 | * </pre> |
525 | * | 526 | * |
526 | */ | 527 | */ |
527 | //US void appHelpActivated( void ); | 528 | //US void appHelpActivated( void ); |
528 | 529 | ||
529 | /** | 530 | /** |
530 | * Apply a state change | 531 | * Apply a state change |
531 | * | 532 | * |
532 | * Enable and disable actions as defined in the XML rc file | 533 | * Enable and disable actions as defined in the XML rc file |
533 | * @since 3.1 | 534 | * @since 3.1 |
534 | */ | 535 | */ |
535 | virtual void slotStateChanged(const QString &newstate); | 536 | virtual void slotStateChanged(const QString &newstate); |
536 | 537 | ||
537 | /** | 538 | /** |
538 | * Apply a state change | 539 | * Apply a state change |
539 | * | 540 | * |
540 | * Enable and disable actions as defined in the XML rc file, | 541 | * Enable and disable actions as defined in the XML rc file, |
541 | * can "reverse" the state (disable the actions which should be | 542 | * can "reverse" the state (disable the actions which should be |
542 | * enabled, and vice-versa) if specified. | 543 | * enabled, and vice-versa) if specified. |
543 | * @since 3.1 | 544 | * @since 3.1 |
544 | */ | 545 | */ |
545 | void slotStateChanged(const QString &newstate, | 546 | void slotStateChanged(const QString &newstate, |
546 | KXMLGUIClient::ReverseStateChange); // KDE 4.0: remove this | 547 | KXMLGUIClient::ReverseStateChange); // KDE 4.0: remove this |
547 | 548 | ||
548 | 549 | ||
549 | /** | 550 | /** |
550 | * Apply a state change | 551 | * Apply a state change |
551 | * | 552 | * |
552 | * Enable and disable actions as defined in the XML rc file, | 553 | * Enable and disable actions as defined in the XML rc file, |
553 | * can "reverse" the state (disable the actions which should be | 554 | * can "reverse" the state (disable the actions which should be |
554 | * enabled, and vice-versa) if specified. | 555 | * enabled, and vice-versa) if specified. |
555 | */ | 556 | */ |
556 | // void slotStateChanged(const QString &newstate, | 557 | // void slotStateChanged(const QString &newstate, |
557 | // bool reverse); // KDE 4.0: enable this | 558 | // bool reverse); // KDE 4.0: enable this |
558 | 559 | ||
559 | /** | 560 | /** |
560 | * Tell the main window that it should save its settings when being closed. | 561 | * Tell the main window that it should save its settings when being closed. |
561 | * This is part of the auto-save-settings feature. | 562 | * This is part of the auto-save-settings feature. |
562 | * For everything related to toolbars this happens automatically, | 563 | * For everything related to toolbars this happens automatically, |
563 | * but you have to call setSettingsDirty() in the slot that toggles | 564 | * but you have to call setSettingsDirty() in the slot that toggles |
564 | * the visibility of the statusbar. | 565 | * the visibility of the statusbar. |
565 | */ | 566 | */ |
566 | void setSettingsDirty(); | 567 | void setSettingsDirty(); |
567 | 568 | ||
568 | protected: | 569 | protected: |
569 | void paintEvent( QPaintEvent* e ); | 570 | void paintEvent( QPaintEvent* e ); |
570 | void childEvent( QChildEvent* e); | 571 | void childEvent( QChildEvent* e); |
571 | void resizeEvent( QResizeEvent* e); | 572 | void resizeEvent( QResizeEvent* e); |
572 | /** | 573 | /** |
573 | * Reimplemented to call the queryClose() and queryExit() handlers. | 574 | * Reimplemented to call the queryClose() and queryExit() handlers. |
574 | * | 575 | * |
575 | * We recommend that you reimplement the handlers rather than @ref closeEvent(). | 576 | * We recommend that you reimplement the handlers rather than @ref closeEvent(). |
576 | * If you do it anyway, ensure to call the base implementation to keep | 577 | * If you do it anyway, ensure to call the base implementation to keep |
577 | * @ref queryExit() running. | 578 | * @ref queryExit() running. |
578 | */ | 579 | */ |
579 | virtual void closeEvent ( QCloseEvent *); | 580 | virtual void closeEvent ( QCloseEvent *); |
580 | 581 | ||
581 | // KDE4 This seems to be flawed to me. Either the app has only one | 582 | // KDE4 This seems to be flawed to me. Either the app has only one |
582 | // mainwindow, so queryClose() is enough, or if it can have more of them, | 583 | // mainwindow, so queryClose() is enough, or if it can have more of them, |
583 | // then the windows should take care of themselves, and queryExit() | 584 | // then the windows should take care of themselves, and queryExit() |
584 | // would be useful only for the annoying 'really quit' dialog, which | 585 | // would be useful only for the annoying 'really quit' dialog, which |
585 | // also doesn't make sense in apps with multiple mainwindows. | 586 | // also doesn't make sense in apps with multiple mainwindows. |
586 | // And saving configuration in something called queryExit()? IMHO | 587 | // And saving configuration in something called queryExit()? IMHO |
587 | // one can e.g. use KApplication::shutDown(), which if nothing else | 588 | // one can e.g. use KApplication::shutDown(), which if nothing else |
588 | // has at least better fitting name. | 589 | // has at least better fitting name. |
589 | // See also KApplication::sessionSaving(). | 590 | // See also KApplication::sessionSaving(). |
590 | // This stuff should get changed somehow, so that it at least doesn't | 591 | // This stuff should get changed somehow, so that it at least doesn't |
591 | // mess with session management. | 592 | // mess with session management. |
592 | /** | 593 | /** |
593 | Called before the very last window is closed, either by the | 594 | Called before the very last window is closed, either by the |
594 | user or indirectly by the session manager. | 595 | user or indirectly by the session manager. |
595 | 596 | ||
596 | It is not recommended to do any user interaction in this | 597 | It is not recommended to do any user interaction in this |
597 | function other than indicating severe errors. Better ask the | 598 | function other than indicating severe errors. Better ask the |
598 | user on @ref queryClose() (see below). | 599 | user on @ref queryClose() (see below). |
599 | 600 | ||
600 | A typical usage of @ref queryExit() is to write configuration data back. | 601 | A typical usage of @ref queryExit() is to write configuration data back. |
601 | Note that the application may continue to run after @ref queryExit() | 602 | Note that the application may continue to run after @ref queryExit() |
602 | (the user may have cancelled a shutdown), so you should not do any cleanups | 603 | (the user may have cancelled a shutdown), so you should not do any cleanups |
603 | here. The purpose of @ref queryExit() is purely to prepare the application | 604 | here. The purpose of @ref queryExit() is purely to prepare the application |
604 | (with possible user interaction) so it can safely be closed later (without | 605 | (with possible user interaction) so it can safely be closed later (without |
605 | user interaction). | 606 | user interaction). |
606 | 607 | ||
607 | If you need to do serious things on exit (like shutting a | 608 | If you need to do serious things on exit (like shutting a |
608 | dial-up connection down), connect to the signal | 609 | dial-up connection down), connect to the signal |
609 | @ref KApplication::shutDown(). | 610 | @ref KApplication::shutDown(). |
610 | 611 | ||
611 | Default implementation returns @p true. Returning @p false will | 612 | Default implementation returns @p true. Returning @p false will |
612 | cancel the exiting. In the latter case, the last window will | 613 | cancel the exiting. In the latter case, the last window will |
613 | remain visible. If KApplication::sessionSaving() is true, refusing | 614 | remain visible. If KApplication::sessionSaving() is true, refusing |
614 | the exit will also cancel KDE logout. | 615 | the exit will also cancel KDE logout. |
615 | 616 | ||
616 | @see queryClose() | 617 | @see queryClose() |
617 | @see KApplication::sessionSaving() | 618 | @see KApplication::sessionSaving() |
618 | */ | 619 | */ |
619 | virtual bool queryExit(); | 620 | virtual bool queryExit(); |
620 | 621 | ||
621 | /** | 622 | /** |
622 | Called before the window is closed, either by the user or indirectly by | 623 | Called before the window is closed, either by the user or indirectly by |
623 | the session manager. | 624 | the session manager. |
624 | 625 | ||
625 | The purpose of this function is to prepare the window in a way that it is | 626 | The purpose of this function is to prepare the window in a way that it is |
626 | safe to close it, i.e. without the user losing some data. | 627 | safe to close it, i.e. without the user losing some data. |
627 | 628 | ||
628 | Default implementation returns true. Returning @p false will cancel | 629 | Default implementation returns true. Returning @p false will cancel |
629 | the closing, and, if KApplication::sessionSaving() is true, it will also | 630 | the closing, and, if KApplication::sessionSaving() is true, it will also |
630 | cancel KDE logout. | 631 | cancel KDE logout. |
631 | 632 | ||
632 | Reimplement this function to prevent the user from losing data. | 633 | Reimplement this function to prevent the user from losing data. |
633 | Example: | 634 | Example: |
634 | <pre> | 635 | <pre> |
635 | 636 | ||
636 | switch ( KMessageBox::warningYesNoCancel( this, | 637 | switch ( KMessageBox::warningYesNoCancel( this, |
637 | i18n("Save changes to document foo?")) ) { | 638 | i18n("Save changes to document foo?")) ) { |
638 | case KMessageBox::Yes : | 639 | case KMessageBox::Yes : |
639 | // save document here. If saving fails, return FALSE; | 640 | // save document here. If saving fails, return FALSE; |
640 | return TRUE; | 641 | return TRUE; |
641 | case KMessageBox::No : | 642 | case KMessageBox::No : |
642 | return TRUE; | 643 | return TRUE; |
643 | default: // cancel | 644 | default: // cancel |
644 | return FALSE; | 645 | return FALSE; |
645 | 646 | ||
646 | </pre> | 647 | </pre> |
647 | 648 | ||
648 | @see queryExit() | 649 | @see queryExit() |
649 | @see KApplication::sessionSaving() | 650 | @see KApplication::sessionSaving() |
650 | 651 | ||
651 | */ | 652 | */ |
652 | virtual bool queryClose(); | 653 | virtual bool queryClose(); |
653 | /** | 654 | /** |
654 | * Save your instance-specific properties. The function is | 655 | * Save your instance-specific properties. The function is |
655 | * invoked when the session manager requests your application | 656 | * invoked when the session manager requests your application |
656 | * to save its state. | 657 | * to save its state. |
657 | * | 658 | * |
658 | * You @em must @em not change the group of the @p kconfig object, since | 659 | * You @em must @em not change the group of the @p kconfig object, since |
659 | * KMainWindow uses one group for each window. Please | 660 | * KMainWindow uses one group for each window. Please |
660 | * reimplement these function in childclasses. | 661 | * reimplement these function in childclasses. |
661 | * | 662 | * |
662 | * Note: No user interaction is allowed | 663 | * Note: No user interaction is allowed |
663 | * in this function! | 664 | * in this function! |
664 | * | 665 | * |
665 | */ | 666 | */ |
666 | virtual void saveProperties( KConfig* ) {} | 667 | virtual void saveProperties( KConfig* ) {} |
667 | 668 | ||
668 | /** | 669 | /** |
669 | * Read your instance-specific properties. | 670 | * Read your instance-specific properties. |
670 | */ | 671 | */ |
671 | virtual void readProperties( KConfig* ) {} | 672 | virtual void readProperties( KConfig* ) {} |
672 | 673 | ||
673 | /** | 674 | /** |
674 | * Save your application-wide properties. The function is | 675 | * Save your application-wide properties. The function is |
675 | * invoked when the session manager requests your application | 676 | * invoked when the session manager requests your application |
676 | * to save its state. | 677 | * to save its state. |
677 | * | 678 | * |
678 | * This function is similar to @ref saveProperties() but is only called for | 679 | * This function is similar to @ref saveProperties() but is only called for |
679 | * the very first main window, regardless how many main window are open. | 680 | * the very first main window, regardless how many main window are open. |
680 | 681 | ||
681 | * Override it if you need to save other data about your documents on | 682 | * Override it if you need to save other data about your documents on |
682 | * session end. sessionConfig is a config to which that data should be | 683 | * session end. sessionConfig is a config to which that data should be |
683 | * saved. Normally, you don't need this function. But if you want to save | 684 | * saved. Normally, you don't need this function. But if you want to save |
684 | * data about your documents that are not in opened windows you might need | 685 | * data about your documents that are not in opened windows you might need |
685 | * it. | 686 | * it. |
686 | * | 687 | * |
687 | * Default implementation does nothing. | 688 | * Default implementation does nothing. |
688 | */ | 689 | */ |
689 | virtual void saveGlobalProperties( KConfig* sessionConfig ); | 690 | virtual void saveGlobalProperties( KConfig* sessionConfig ); |
690 | 691 | ||
691 | /** | 692 | /** |
692 | * The counterpart of @ref saveGlobalProperties(). | 693 | * The counterpart of @ref saveGlobalProperties(). |
693 | * | 694 | * |
694 | * Read the application-specific properties in again. | 695 | * Read the application-specific properties in again. |
695 | */ | 696 | */ |
696 | virtual void readGlobalProperties( KConfig* sessionConfig ); | 697 | virtual void readGlobalProperties( KConfig* sessionConfig ); |
697 | void savePropertiesInternal( KConfig*, int ); | 698 | void savePropertiesInternal( KConfig*, int ); |
698 | bool readPropertiesInternal( KConfig*, int ); | 699 | bool readPropertiesInternal( KConfig*, int ); |
699 | 700 | ||
700 | /** | 701 | /** |
701 | * For inherited classes | 702 | * For inherited classes |
702 | */ | 703 | */ |
703 | bool settingsDirty() const; | 704 | bool settingsDirty() const; |
704 | /** | 705 | /** |
705 | * For inherited classes | 706 | * For inherited classes |
706 | */ | 707 | */ |
707 | QString settingsGroup() const; | 708 | QString settingsGroup() const; |
708 | /** | 709 | /** |
709 | * For inherited classes | 710 | * For inherited classes |
710 | * Note that the group must be set before calling | 711 | * Note that the group must be set before calling |
711 | */ | 712 | */ |
712 | void saveWindowSize( KConfig * config ) const; | 713 | void saveWindowSize( KConfig * config ) const; |
713 | /** | 714 | /** |
714 | * For inherited classes | 715 | * For inherited classes |
715 | * Note that the group must be set before calling, and that | 716 | * Note that the group must be set before calling, and that |
716 | * a -geometry on the command line has priority. | 717 | * a -geometry on the command line has priority. |
717 | */ | 718 | */ |
718 | void restoreWindowSize( KConfig * config ); | 719 | void restoreWindowSize( KConfig * config ); |
719 | 720 | ||
720 | /// parse the geometry from the geometry command line argument | 721 | /// parse the geometry from the geometry command line argument |
721 | void parseGeometry(bool parsewidth); | 722 | void parseGeometry(bool parsewidth); |
722 | 723 | ||
723 | protected slots: | 724 | protected slots: |
724 | 725 | ||
725 | /** | 726 | /** |
726 | * This slot does nothing. | 727 | * This slot does nothing. |
727 | * | 728 | * |
728 | * It must be reimplemented if you want | 729 | * It must be reimplemented if you want |
729 | * to use a custom About Application dialog box. This slot is | 730 | * to use a custom About Application dialog box. This slot is |
730 | * connected to the About Application entry in the menu returned | 731 | * connected to the About Application entry in the menu returned |
731 | * by @ref customHelpMenu. | 732 | * by @ref customHelpMenu. |
732 | * | 733 | * |
733 | * Example: | 734 | * Example: |
734 | * <pre> | 735 | * <pre> |
735 | * | 736 | * |
736 | * void MyMainLevel::setupInterface() | 737 | * void MyMainLevel::setupInterface() |
737 | * { | 738 | * { |
738 | * .. | 739 | * .. |
739 | * menuBar()->insertItem( i18n("&Help"), customHelpMenu() ); | 740 | * menuBar()->insertItem( i18n("&Help"), customHelpMenu() ); |
740 | * .. | 741 | * .. |
741 | * } | 742 | * } |
742 | * | 743 | * |
743 | * void MyMainLevel::showAboutApplication() | 744 | * void MyMainLevel::showAboutApplication() |
744 | * { | 745 | * { |
745 | * <activate your custom dialog> | 746 | * <activate your custom dialog> |
746 | * } | 747 | * } |
747 | * </pre> | 748 | * </pre> |
748 | */ | 749 | */ |
749 | //US virtual void showAboutApplication(); | 750 | //US virtual void showAboutApplication(); |
750 | 751 | ||
751 | private slots: | 752 | private slots: |
752 | /** | 753 | /** |
753 | * Called when the app is shutting down. | 754 | * Called when the app is shutting down. |
754 | */ | 755 | */ |
755 | void shuttingDown(); | 756 | void shuttingDown(); |
756 | 757 | ||
757 | void saveAutoSaveSettings(); | 758 | void saveAutoSaveSettings(); |
758 | 759 | ||
759 | private: | 760 | private: |
760 | QToolBar * mQToolBar; | 761 | QToolBar * mQToolBar; |
761 | //US KMenuBar *internalMenuBar(); | 762 | //US KMenuBar *internalMenuBar(); |
762 | QMenuBar *internalMenuBar(); | 763 | QMenuBar *internalMenuBar(); |
763 | //US KStatusBar *internalStatusBar(); | 764 | //US KStatusBar *internalStatusBar(); |
764 | QStatusBar *internalStatusBar(); | 765 | QStatusBar *internalStatusBar(); |
765 | 766 | ||
766 | KMainWindowPrivate *d; | 767 | KMainWindowPrivate *d; |
767 | void initKMainWindow(const char *name); | 768 | void initKMainWindow(const char *name); |
768 | 769 | ||
769 | QPtrList<KToolBar> toolbarList; | 770 | QPtrList<KToolBar> toolbarList; |
770 | 771 | ||
771 | protected: | 772 | protected: |
772 | virtual void virtual_hook( int id, void* data ); | 773 | virtual void virtual_hook( int id, void* data ); |
773 | 774 | ||
774 | }; | 775 | }; |
775 | 776 | ||
776 | #endif | 777 | #endif |