author | sandman <sandman> | 2002-07-28 00:44:43 (UTC) |
---|---|---|
committer | sandman <sandman> | 2002-07-28 00:44:43 (UTC) |
commit | 72081cbfef03a69ed6f9ca7826854b6cf10dc2fe (patch) (unidiff) | |
tree | 43e67bdc7cbb972f431b3912e2f068df3d2c97bf | |
parent | 4baf36396739502c5471950e29f18954cca4517b (diff) | |
download | opie-72081cbfef03a69ed6f9ca7826854b6cf10dc2fe.zip opie-72081cbfef03a69ed6f9ca7826854b6cf10dc2fe.tar.gz opie-72081cbfef03a69ed6f9ca7826854b6cf10dc2fe.tar.bz2 |
Workaround for a weird Qt/E bug, resulting in qpe hanging if clipboard
applet is loaded and qpe is terminated via shutdown applet.
-rw-r--r-- | core/applets/clipboardapplet/clipboard.cpp | 15 | ||||
-rw-r--r-- | core/applets/clipboardapplet/clipboard.h | 4 | ||||
-rw-r--r-- | core/launcher/desktop.cpp | 6 |
3 files changed, 22 insertions, 3 deletions
diff --git a/core/applets/clipboardapplet/clipboard.cpp b/core/applets/clipboardapplet/clipboard.cpp index 5848d0f..4fbdf6f 100644 --- a/core/applets/clipboardapplet/clipboard.cpp +++ b/core/applets/clipboardapplet/clipboard.cpp | |||
@@ -1,233 +1,242 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | 20 | ||
21 | #include "clipboard.h" | 21 | #include "clipboard.h" |
22 | 22 | ||
23 | #include <qpe/resource.h> | 23 | #include <qpe/resource.h> |
24 | 24 | ||
25 | #include <qpainter.h> | 25 | #include <qpainter.h> |
26 | #include <qpopupmenu.h> | 26 | #include <qpopupmenu.h> |
27 | #include <qwindowsystem_qws.h> | 27 | #include <qwindowsystem_qws.h> |
28 | #include <qapplication.h> | 28 | #include <qapplication.h> |
29 | #include <qclipboard.h> | 29 | #include <qclipboard.h> |
30 | #include <qtimer.h> | 30 | #include <qtimer.h> |
31 | 31 | ||
32 | //=========================================================================== | 32 | //=========================================================================== |
33 | 33 | ||
34 | /* XPM */ | 34 | /* XPM */ |
35 | static const char * paste_xpm[] = { | 35 | static const char * paste_xpm[] = { |
36 | "14 16 64 1", | 36 | "14 16 64 1", |
37 | " c None", | 37 | " c None", |
38 | ".c #020202", | 38 | ".c #020202", |
39 | "+c #867616", | 39 | "+c #867616", |
40 | "@c #A69A42", | 40 | "@c #A69A42", |
41 | "#c #BAB676", | 41 | "#c #BAB676", |
42 | "$c #060606", | 42 | "$c #060606", |
43 | "%c #EAD2AA", | 43 | "%c #EAD2AA", |
44 | "&c #F6F6DA", | 44 | "&c #F6F6DA", |
45 | "*c #222212", | 45 | "*c #222212", |
46 | "=c #86761E", | 46 | "=c #86761E", |
47 | "-c #868686", | 47 | "-c #868686", |
48 | ";c #5A5202", | 48 | ";c #5A5202", |
49 | ">c #8A7E2E", | 49 | ">c #8A7E2E", |
50 | ",c #2C2C2C", | 50 | ",c #2C2C2C", |
51 | "'c #9A9A9A", | 51 | "'c #9A9A9A", |
52 | ")c #F6EADA", | 52 | ")c #F6EADA", |
53 | "!c #AAA262", | 53 | "!c #AAA262", |
54 | "~c #323232", | 54 | "~c #323232", |
55 | "{c #726A32", | 55 | "{c #726A32", |
56 | "]c #6E6E6E", | 56 | "]c #6E6E6E", |
57 | "^c #C2B69E", | 57 | "^c #C2B69E", |
58 | "/c #9E9E9E", | 58 | "/c #9E9E9E", |
59 | "(c #EED6BA", | 59 | "(c #EED6BA", |
60 | "_c #F2DEC2", | 60 | "_c #F2DEC2", |
61 | ":c #D2CE8E", | 61 | ":c #D2CE8E", |
62 | "<c #3A3A3A", | 62 | "<c #3A3A3A", |
63 | "[c #EACAA2", | 63 | "[c #EACAA2", |
64 | "}c #3E3E3E", | 64 | "}c #3E3E3E", |
65 | "|c #727272", | 65 | "|c #727272", |
66 | "1c #CECECE", | 66 | "1c #CECECE", |
67 | "2c #929292", | 67 | "2c #929292", |
68 | "3c #4A462A", | 68 | "3c #4A462A", |
69 | "4c #424242", | 69 | "4c #424242", |
70 | "5c #666666", | 70 | "5c #666666", |
71 | "6c #C2AE96", | 71 | "6c #C2AE96", |
72 | "7c #767676", | 72 | "7c #767676", |
73 | "8c #D6D6D6", | 73 | "8c #D6D6D6", |
74 | "9c #C2C2C2", | 74 | "9c #C2C2C2", |
75 | "0c #BFA681", | 75 | "0c #BFA681", |
76 | "ac #1E1E1E", | 76 | "ac #1E1E1E", |
77 | "bc #FAF6F3", | 77 | "bc #FAF6F3", |
78 | "cc #AEAEAE", | 78 | "cc #AEAEAE", |
79 | "dc #C29A6A", | 79 | "dc #C29A6A", |
80 | "ec #FEFEFE", | 80 | "ec #FEFEFE", |
81 | "fc #B6B6B6", | 81 | "fc #B6B6B6", |
82 | "gc #7E7E7E", | 82 | "gc #7E7E7E", |
83 | "hc #FAF2E6", | 83 | "hc #FAF2E6", |
84 | "ic #8E8E8E", | 84 | "ic #8E8E8E", |
85 | "jc #C6BCAE", | 85 | "jc #C6BCAE", |
86 | "kc #DEDEDE", | 86 | "kc #DEDEDE", |
87 | "lc #BEBEBE", | 87 | "lc #BEBEBE", |
88 | "mc #464646", | 88 | "mc #464646", |
89 | "nc #BEAE92", | 89 | "nc #BEAE92", |
90 | "oc #262626", | 90 | "oc #262626", |
91 | "pc #F2E2CE", | 91 | "pc #F2E2CE", |
92 | "qc #C2A175", | 92 | "qc #C2A175", |
93 | "rc #CACACA", | 93 | "rc #CACACA", |
94 | "sc #969696", | 94 | "sc #969696", |
95 | "tc #8A8A8A", | 95 | "tc #8A8A8A", |
96 | "uc #828282", | 96 | "uc #828282", |
97 | "vc #6A6A6A", | 97 | "vc #6A6A6A", |
98 | "wc #BEB6AE", | 98 | "wc #BEB6AE", |
99 | "xc #E2E0E0", | 99 | "xc #E2E0E0", |
100 | "yc #7A7A7A", | 100 | "yc #7A7A7A", |
101 | " *{>; ", | 101 | " *{>; ", |
102 | " }}}@e:!;}}} ", | 102 | " }}}@e:!;}}} ", |
103 | "<x8=&:#@+;ll, ", | 103 | "<x8=&:#@+;ll, ", |
104 | "}k/=;;3}337|o ", | 104 | "}k/=;;3}337|o ", |
105 | "<k's24444m45o ", | 105 | "<k's24444m45o ", |
106 | "}8'ss4xkkk]}a ", | 106 | "}8'ss4xkkk]}a ", |
107 | "<1s224keee|b4 ", | 107 | "<1s224keee|b4 ", |
108 | "}r2itmkeee]]44", | 108 | "}r2itmkeee]]44", |
109 | "<9iitmkeeehkw.", | 109 | "<9iitmkeeehkw.", |
110 | "<lt-u4keeb)pn.", | 110 | "<lt-u4keeb)pn.", |
111 | "<fu-umkebhp(0.", | 111 | "<fu-umkebhp(0.", |
112 | "<cugg4kbh)_(q.", | 112 | "<cugg4kbh)_(q.", |
113 | "<cyyymk))p(%q.", | 113 | "<cyyymk))p(%q.", |
114 | ",5vvv4k)p_%[q.", | 114 | ",5vvv4k)p_%[q.", |
115 | " ...$mljnn0qd.", | 115 | " ...$mljnn0qd.", |
116 | " 4.......,"}; | 116 | " 4.......,"}; |
117 | 117 | ||
118 | 118 | ||
119 | ClipboardApplet::ClipboardApplet( QWidget *parent, const char *name ) : QWidget( parent, name ) | 119 | ClipboardApplet::ClipboardApplet( QWidget *parent, const char *name ) : QWidget( parent, name ) |
120 | { | 120 | { |
121 | setFixedWidth ( 14 ); | 121 | setFixedWidth ( 14 ); |
122 | setFixedHeight ( 18 ); | 122 | setFixedHeight ( 18 ); |
123 | m_clipboardPixmap = QPixmap ( paste_xpm ); | 123 | m_clipboardPixmap = QPixmap ( paste_xpm ); |
124 | 124 | ||
125 | QTimer *timer = new QTimer ( this ); | 125 | m_timer = new QTimer ( this ); |
126 | 126 | ||
127 | connect ( QApplication::clipboard ( ), SIGNAL( dataChanged ( )), this, SLOT( newData ( ))); | 127 | connect ( QApplication::clipboard ( ), SIGNAL( dataChanged ( )), this, SLOT( newData ( ))); |
128 | connect ( timer, SIGNAL( timeout ( )), this, SLOT( newData ( ))); | 128 | connect ( m_timer, SIGNAL( timeout ( )), this, SLOT( newData ( ))); |
129 | connect ( qApp, SIGNAL( aboutToQuit ( )), this, SLOT( shutdown ( ))); | ||
129 | 130 | ||
130 | timer-> start ( 1000 ); | 131 | m_timer-> start ( 1500 ); |
131 | 132 | ||
132 | m_menu = 0; | 133 | m_menu = 0; |
133 | m_dirty = true; | 134 | m_dirty = true; |
134 | m_lasttext = QString::null; | 135 | m_lasttext = QString::null; |
135 | } | 136 | } |
136 | 137 | ||
137 | ClipboardApplet::~ClipboardApplet ( ) | 138 | ClipboardApplet::~ClipboardApplet ( ) |
138 | { | 139 | { |
139 | } | 140 | } |
140 | 141 | ||
142 | void ClipboardApplet::shutdown ( ) | ||
143 | { | ||
144 | // the timer has to be stopped, or Qt/E will hang on quit() | ||
145 | // see launcher/desktop.cpp | ||
146 | |||
147 | m_timer-> stop ( ); | ||
148 | } | ||
149 | |||
141 | void ClipboardApplet::mousePressEvent ( QMouseEvent *) | 150 | void ClipboardApplet::mousePressEvent ( QMouseEvent *) |
142 | { | 151 | { |
143 | if ( m_dirty ) { | 152 | if ( m_dirty ) { |
144 | delete m_menu; | 153 | delete m_menu; |
145 | 154 | ||
146 | m_menu = new QPopupMenu ( this ); | 155 | m_menu = new QPopupMenu ( this ); |
147 | m_menu-> setCheckable ( true ); | 156 | m_menu-> setCheckable ( true ); |
148 | 157 | ||
149 | if ( m_history. count ( )) { | 158 | if ( m_history. count ( )) { |
150 | for ( unsigned int i = 0; i < m_history. count ( ); i++ ) { | 159 | for ( unsigned int i = 0; i < m_history. count ( ); i++ ) { |
151 | QString str = m_history [i]; | 160 | QString str = m_history [i]; |
152 | 161 | ||
153 | if ( str. length ( ) > 20 ) | 162 | if ( str. length ( ) > 20 ) |
154 | str = str. left ( 20 ) + "..."; | 163 | str = str. left ( 20 ) + "..."; |
155 | 164 | ||
156 | m_menu-> insertItem ( QString ( "%1: %2" ). arg ( i + 1 ). arg ( str ), i ); | 165 | m_menu-> insertItem ( QString ( "%1: %2" ). arg ( i + 1 ). arg ( str ), i ); |
157 | m_menu-> setItemChecked ( i, false ); | 166 | m_menu-> setItemChecked ( i, false ); |
158 | } | 167 | } |
159 | m_menu-> setItemChecked ( m_history. count ( ) - 1, true ); | 168 | m_menu-> setItemChecked ( m_history. count ( ) - 1, true ); |
160 | m_menu-> insertSeparator ( ); | 169 | m_menu-> insertSeparator ( ); |
161 | } | 170 | } |
162 | m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "cut" )), tr( "Cut" ), 100 ); | 171 | m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "cut" )), tr( "Cut" ), 100 ); |
163 | m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "copy" )), tr( "Copy" ), 101 ); | 172 | m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "copy" )), tr( "Copy" ), 101 ); |
164 | m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "paste" )), tr( "Paste" ), 102 ); | 173 | m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "paste" )), tr( "Paste" ), 102 ); |
165 | 174 | ||
166 | connect ( m_menu, SIGNAL( activated ( int )), this, SLOT( action ( int ))); | 175 | connect ( m_menu, SIGNAL( activated ( int )), this, SLOT( action ( int ))); |
167 | 176 | ||
168 | m_dirty = false; | 177 | m_dirty = false; |
169 | } | 178 | } |
170 | QPoint p = mapToGlobal ( QPoint ( 0, 0 )); | 179 | QPoint p = mapToGlobal ( QPoint ( 0, 0 )); |
171 | QSize s = m_menu-> sizeHint ( ); | 180 | QSize s = m_menu-> sizeHint ( ); |
172 | 181 | ||
173 | m_menu-> popup ( QPoint ( p. x ( ) + ( width ( ) / 2 ) - ( s. width ( ) / 2 ), p. y ( ) - s. height ( ))); | 182 | m_menu-> popup ( QPoint ( p. x ( ) + ( width ( ) / 2 ) - ( s. width ( ) / 2 ), p. y ( ) - s. height ( ))); |
174 | } | 183 | } |
175 | 184 | ||
176 | void ClipboardApplet::action(int id) | 185 | void ClipboardApplet::action(int id) |
177 | { | 186 | { |
178 | ushort unicode = 0; | 187 | ushort unicode = 0; |
179 | int scan = 0; | 188 | int scan = 0; |
180 | 189 | ||
181 | switch ( id ) { | 190 | switch ( id ) { |
182 | case 100: | 191 | case 100: |
183 | unicode = 'X' - '@'; | 192 | unicode = 'X' - '@'; |
184 | scan = Key_X; // Cut | 193 | scan = Key_X; // Cut |
185 | break; | 194 | break; |
186 | case 101: | 195 | case 101: |
187 | unicode = 'C' - '@'; | 196 | unicode = 'C' - '@'; |
188 | scan = Key_C; // Copy | 197 | scan = Key_C; // Copy |
189 | break; | 198 | break; |
190 | case 102: | 199 | case 102: |
191 | unicode = 'V' - '@'; | 200 | unicode = 'V' - '@'; |
192 | scan = Key_V; // Paste | 201 | scan = Key_V; // Paste |
193 | break; | 202 | break; |
194 | 203 | ||
195 | default: | 204 | default: |
196 | if (( id >= 0 ) && ( uint( id ) < m_history. count ( ))) { | 205 | if (( id >= 0 ) && ( uint( id ) < m_history. count ( ))) { |
197 | QApplication::clipboard ( )-> setText ( m_history [id] ); | 206 | QApplication::clipboard ( )-> setText ( m_history [id] ); |
198 | 207 | ||
199 | for ( uint i = 0; i < m_history. count ( ); i++ ) | 208 | for ( uint i = 0; i < m_history. count ( ); i++ ) |
200 | m_menu-> setItemChecked ( i, i == uint( id )); | 209 | m_menu-> setItemChecked ( i, i == uint( id )); |
201 | 210 | ||
202 | unicode = 'V' - '@'; | 211 | unicode = 'V' - '@'; |
203 | scan = Key_V; | 212 | scan = Key_V; |
204 | } | 213 | } |
205 | break; | 214 | break; |
206 | } | 215 | } |
207 | 216 | ||
208 | if ( scan ) { | 217 | if ( scan ) { |
209 | qwsServer-> sendKeyEvent ( unicode, scan, ControlButton, true, false ); | 218 | qwsServer-> sendKeyEvent ( unicode, scan, ControlButton, true, false ); |
210 | qwsServer-> sendKeyEvent ( unicode, scan, ControlButton, false, false ); | 219 | qwsServer-> sendKeyEvent ( unicode, scan, ControlButton, false, false ); |
211 | } | 220 | } |
212 | } | 221 | } |
213 | 222 | ||
214 | void ClipboardApplet::paintEvent ( QPaintEvent* ) | 223 | void ClipboardApplet::paintEvent ( QPaintEvent* ) |
215 | { | 224 | { |
216 | QPainter p ( this ); | 225 | QPainter p ( this ); |
217 | p. drawPixmap ( 0, 1, m_clipboardPixmap ); | 226 | p. drawPixmap ( 0, 1, m_clipboardPixmap ); |
218 | } | 227 | } |
219 | 228 | ||
220 | void ClipboardApplet::newData ( ) | 229 | void ClipboardApplet::newData ( ) |
221 | { | 230 | { |
222 | QCString type = "plain"; | 231 | QCString type = "plain"; |
223 | QString txt = QApplication::clipboard ( )-> text ( type ); | 232 | QString txt = QApplication::clipboard ( )-> text ( type ); |
224 | 233 | ||
225 | if ( !txt. isEmpty ( ) && !m_history. contains ( txt )) { | 234 | if ( !txt. isEmpty ( ) && !m_history. contains ( txt )) { |
226 | m_history. append ( txt ); | 235 | m_history. append ( txt ); |
227 | 236 | ||
228 | if ( m_history. count ( ) > 5 ) | 237 | if ( m_history. count ( ) > 5 ) |
229 | m_history. remove ( m_history. begin ( )); | 238 | m_history. remove ( m_history. begin ( )); |
230 | 239 | ||
231 | m_dirty = true; | 240 | m_dirty = true; |
232 | } | 241 | } |
233 | } | 242 | } |
diff --git a/core/applets/clipboardapplet/clipboard.h b/core/applets/clipboardapplet/clipboard.h index 84743d9..ec87d39 100644 --- a/core/applets/clipboardapplet/clipboard.h +++ b/core/applets/clipboardapplet/clipboard.h | |||
@@ -1,53 +1,57 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2000 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qtopia Environment. | 4 | ** This file is part of Qtopia Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | #ifndef __CLIPBOARD_APPLET_H__ | 20 | #ifndef __CLIPBOARD_APPLET_H__ |
21 | #define __CLIPBOARD_APPLET_H__ | 21 | #define __CLIPBOARD_APPLET_H__ |
22 | 22 | ||
23 | #include <qwidget.h> | 23 | #include <qwidget.h> |
24 | #include <qpixmap.h> | 24 | #include <qpixmap.h> |
25 | #include <qstringlist.h> | 25 | #include <qstringlist.h> |
26 | 26 | ||
27 | class QTimer; | ||
28 | |||
27 | class ClipboardApplet : public QWidget | 29 | class ClipboardApplet : public QWidget |
28 | { | 30 | { |
29 | Q_OBJECT | 31 | Q_OBJECT |
30 | public: | 32 | public: |
31 | ClipboardApplet ( QWidget *parent = 0, const char *name=0 ); | 33 | ClipboardApplet ( QWidget *parent = 0, const char *name=0 ); |
32 | ~ClipboardApplet ( ); | 34 | ~ClipboardApplet ( ); |
33 | 35 | ||
34 | protected: | 36 | protected: |
35 | void mousePressEvent ( QMouseEvent *); | 37 | void mousePressEvent ( QMouseEvent *); |
36 | void paintEvent ( QPaintEvent* ); | 38 | void paintEvent ( QPaintEvent* ); |
37 | 39 | ||
38 | private slots: | 40 | private slots: |
39 | void action ( int ); | 41 | void action ( int ); |
40 | void newData ( ); | 42 | void newData ( ); |
43 | void shutdown ( ); | ||
41 | 44 | ||
42 | private: | 45 | private: |
43 | QPopupMenu * m_menu; | 46 | QPopupMenu * m_menu; |
44 | QStringList m_history; | 47 | QStringList m_history; |
45 | bool m_dirty; | 48 | bool m_dirty; |
46 | QString m_lasttext; | 49 | QString m_lasttext; |
50 | QTimer * m_timer; | ||
47 | 51 | ||
48 | QPixmap m_clipboardPixmap; | 52 | QPixmap m_clipboardPixmap; |
49 | }; | 53 | }; |
50 | 54 | ||
51 | 55 | ||
52 | #endif // __CLIPBOARD_APPLET_H__ | 56 | #endif // __CLIPBOARD_APPLET_H__ |
53 | 57 | ||
diff --git a/core/launcher/desktop.cpp b/core/launcher/desktop.cpp index e58b08c..f90da1a 100644 --- a/core/launcher/desktop.cpp +++ b/core/launcher/desktop.cpp | |||
@@ -497,294 +497,300 @@ void Desktop::executeOrModify(const QString& appLnkFile) | |||
497 | } | 497 | } |
498 | } | 498 | } |
499 | } | 499 | } |
500 | 500 | ||
501 | void Desktop::raiseDatebook() | 501 | void Desktop::raiseDatebook() |
502 | { | 502 | { |
503 | Config cfg("qpe"); //F9 'Activity' | 503 | Config cfg("qpe"); //F9 'Activity' |
504 | cfg.setGroup("AppsKey"); | 504 | cfg.setGroup("AppsKey"); |
505 | QString tempItem; | 505 | QString tempItem; |
506 | tempItem = cfg.readEntry("LeftEnd","Calender"); | 506 | tempItem = cfg.readEntry("LeftEnd","Calender"); |
507 | if(tempItem == "Calender" || tempItem.isEmpty()) executeOrModify("Applications/datebook.desktop"); | 507 | if(tempItem == "Calender" || tempItem.isEmpty()) executeOrModify("Applications/datebook.desktop"); |
508 | else { | 508 | else { |
509 | QCopEnvelope e("QPE/System","execute(QString)"); | 509 | QCopEnvelope e("QPE/System","execute(QString)"); |
510 | e << tempItem; | 510 | e << tempItem; |
511 | } | 511 | } |
512 | } | 512 | } |
513 | 513 | ||
514 | void Desktop::raiseContacts() | 514 | void Desktop::raiseContacts() |
515 | { | 515 | { |
516 | Config cfg("qpe"); //F10, 'Contacts' | 516 | Config cfg("qpe"); //F10, 'Contacts' |
517 | cfg.setGroup("AppsKey"); | 517 | cfg.setGroup("AppsKey"); |
518 | QString tempItem; | 518 | QString tempItem; |
519 | tempItem = cfg.readEntry("Left2nd","Address Book"); | 519 | tempItem = cfg.readEntry("Left2nd","Address Book"); |
520 | if(tempItem == "Address Book" || tempItem.isEmpty()) executeOrModify("Applications/addressbook.desktop"); | 520 | if(tempItem == "Address Book" || tempItem.isEmpty()) executeOrModify("Applications/addressbook.desktop"); |
521 | else { | 521 | else { |
522 | QCopEnvelope e("QPE/System","execute(QString)"); | 522 | QCopEnvelope e("QPE/System","execute(QString)"); |
523 | e << tempItem; | 523 | e << tempItem; |
524 | } | 524 | } |
525 | } | 525 | } |
526 | 526 | ||
527 | void Desktop::raiseMenu() | 527 | void Desktop::raiseMenu() |
528 | { | 528 | { |
529 | Config cfg("qpe"); //F11, 'Menu' | 529 | Config cfg("qpe"); //F11, 'Menu' |
530 | cfg.setGroup("AppsKey"); | 530 | cfg.setGroup("AppsKey"); |
531 | QString tempItem; | 531 | QString tempItem; |
532 | tempItem = cfg.readEntry("Right2nd","Popup Menu"); | 532 | tempItem = cfg.readEntry("Right2nd","Popup Menu"); |
533 | if(tempItem == "Popup Menu" || tempItem.isEmpty()) { | 533 | if(tempItem == "Popup Menu" || tempItem.isEmpty()) { |
534 | Global::terminateBuiltin("calibrate"); | 534 | Global::terminateBuiltin("calibrate"); |
535 | tb->startMenu()->launch(); | 535 | tb->startMenu()->launch(); |
536 | } else { | 536 | } else { |
537 | QCopEnvelope e("QPE/System","execute(QString)"); | 537 | QCopEnvelope e("QPE/System","execute(QString)"); |
538 | e << tempItem; | 538 | e << tempItem; |
539 | } | 539 | } |
540 | } | 540 | } |
541 | 541 | ||
542 | void Desktop::raiseEmail() | 542 | void Desktop::raiseEmail() |
543 | { | 543 | { |
544 | Config cfg("qpe"); //F13, 'Mail' | 544 | Config cfg("qpe"); //F13, 'Mail' |
545 | cfg.setGroup("AppsKey"); | 545 | cfg.setGroup("AppsKey"); |
546 | QString tempItem; | 546 | QString tempItem; |
547 | tempItem = cfg.readEntry("RightEnd","Mail"); | 547 | tempItem = cfg.readEntry("RightEnd","Mail"); |
548 | if(tempItem == "Mail" || tempItem == "qtmail" || tempItem.isEmpty()) executeOrModify("Applications/qtmail.desktop"); | 548 | if(tempItem == "Mail" || tempItem == "qtmail" || tempItem.isEmpty()) executeOrModify("Applications/qtmail.desktop"); |
549 | else { | 549 | else { |
550 | QCopEnvelope e("QPE/System","execute(QString)"); | 550 | QCopEnvelope e("QPE/System","execute(QString)"); |
551 | e << tempItem; | 551 | e << tempItem; |
552 | } | 552 | } |
553 | } | 553 | } |
554 | 554 | ||
555 | // autoStarts apps on resume and start | 555 | // autoStarts apps on resume and start |
556 | void Desktop::execAutoStart() { | 556 | void Desktop::execAutoStart() { |
557 | QString appName; | 557 | QString appName; |
558 | int delay; | 558 | int delay; |
559 | QDateTime now = QDateTime::currentDateTime(); | 559 | QDateTime now = QDateTime::currentDateTime(); |
560 | Config cfg( "autostart" ); | 560 | Config cfg( "autostart" ); |
561 | cfg.setGroup( "AutoStart" ); | 561 | cfg.setGroup( "AutoStart" ); |
562 | appName = cfg.readEntry("Apps", ""); | 562 | appName = cfg.readEntry("Apps", ""); |
563 | delay = (cfg.readEntry("Delay", "0" )).toInt(); | 563 | delay = (cfg.readEntry("Delay", "0" )).toInt(); |
564 | // If the time between suspend and resume was longer then the | 564 | // If the time between suspend and resume was longer then the |
565 | // value saved as delay, start the app | 565 | // value saved as delay, start the app |
566 | if ( suspendTime.secsTo(now) >= (delay*60) ) { | 566 | if ( suspendTime.secsTo(now) >= (delay*60) ) { |
567 | QCopEnvelope e("QPE/System", "execute(QString)"); | 567 | QCopEnvelope e("QPE/System", "execute(QString)"); |
568 | e << QString(appName); | 568 | e << QString(appName); |
569 | } //else { | 569 | } //else { |
570 | //} | 570 | //} |
571 | } | 571 | } |
572 | 572 | ||
573 | #if defined(QPE_HAVE_TOGGLELIGHT) | 573 | #if defined(QPE_HAVE_TOGGLELIGHT) |
574 | #include <qpe/config.h> | 574 | #include <qpe/config.h> |
575 | 575 | ||
576 | #include <sys/ioctl.h> | 576 | #include <sys/ioctl.h> |
577 | #include <sys/types.h> | 577 | #include <sys/types.h> |
578 | #include <fcntl.h> | 578 | #include <fcntl.h> |
579 | #include <unistd.h> | 579 | #include <unistd.h> |
580 | #include <errno.h> | 580 | #include <errno.h> |
581 | #include <linux/ioctl.h> | 581 | #include <linux/ioctl.h> |
582 | #include <time.h> | 582 | #include <time.h> |
583 | #endif | 583 | #endif |
584 | 584 | ||
585 | static bool blanked=FALSE; | 585 | static bool blanked=FALSE; |
586 | 586 | ||
587 | static void blankScreen() | 587 | static void blankScreen() |
588 | { | 588 | { |
589 | if ( !qt_screen ) return; | 589 | if ( !qt_screen ) return; |
590 | /* Should use a big black window instead. | 590 | /* Should use a big black window instead. |
591 | QGfx* g = qt_screen->screenGfx(); | 591 | QGfx* g = qt_screen->screenGfx(); |
592 | g->fillRect(0,0,qt_screen->width(),qt_screen->height()); | 592 | g->fillRect(0,0,qt_screen->width(),qt_screen->height()); |
593 | delete g; | 593 | delete g; |
594 | */ | 594 | */ |
595 | blanked = TRUE; | 595 | blanked = TRUE; |
596 | } | 596 | } |
597 | 597 | ||
598 | static void darkScreen() | 598 | static void darkScreen() |
599 | { | 599 | { |
600 | extern void qpe_setBacklight(int); | 600 | extern void qpe_setBacklight(int); |
601 | qpe_setBacklight(0); // force off | 601 | qpe_setBacklight(0); // force off |
602 | } | 602 | } |
603 | 603 | ||
604 | 604 | ||
605 | void Desktop::togglePower() | 605 | void Desktop::togglePower() |
606 | { | 606 | { |
607 | bool wasloggedin = loggedin; | 607 | bool wasloggedin = loggedin; |
608 | loggedin=0; | 608 | loggedin=0; |
609 | suspendTime = QDateTime::currentDateTime(); | 609 | suspendTime = QDateTime::currentDateTime(); |
610 | darkScreen(); | 610 | darkScreen(); |
611 | if ( wasloggedin ) | 611 | if ( wasloggedin ) |
612 | blankScreen(); | 612 | blankScreen(); |
613 | 613 | ||
614 | system("apm --suspend"); | 614 | system("apm --suspend"); |
615 | 615 | ||
616 | 616 | ||
617 | 617 | ||
618 | QWSServer::screenSaverActivate( FALSE ); | 618 | QWSServer::screenSaverActivate( FALSE ); |
619 | { | 619 | { |
620 | QCopEnvelope("QPE/Card", "mtabChanged()" ); // might have changed while asleep | 620 | QCopEnvelope("QPE/Card", "mtabChanged()" ); // might have changed while asleep |
621 | QCopEnvelope e("QPE/System", "setBacklight(int)"); | 621 | QCopEnvelope e("QPE/System", "setBacklight(int)"); |
622 | e << -3; // Force on | 622 | e << -3; // Force on |
623 | } | 623 | } |
624 | if ( wasloggedin ) { | 624 | if ( wasloggedin ) { |
625 | login(TRUE); | 625 | login(TRUE); |
626 | } | 626 | } |
627 | sleep(1); | 627 | sleep(1); |
628 | execAutoStart(); | 628 | execAutoStart(); |
629 | //qcopBridge->closeOpenConnections(); | 629 | //qcopBridge->closeOpenConnections(); |
630 | //qDebug("called togglePower()!!!!!!"); | 630 | //qDebug("called togglePower()!!!!!!"); |
631 | } | 631 | } |
632 | 632 | ||
633 | void Desktop::toggleLight() | 633 | void Desktop::toggleLight() |
634 | { | 634 | { |
635 | QCopEnvelope e("QPE/System", "setBacklight(int)"); | 635 | QCopEnvelope e("QPE/System", "setBacklight(int)"); |
636 | e << -2; // toggle | 636 | e << -2; // toggle |
637 | } | 637 | } |
638 | 638 | ||
639 | void Desktop::toggleSymbolInput() | 639 | void Desktop::toggleSymbolInput() |
640 | { | 640 | { |
641 | tb->toggleSymbolInput(); | 641 | tb->toggleSymbolInput(); |
642 | } | 642 | } |
643 | 643 | ||
644 | void Desktop::toggleNumLockState() | 644 | void Desktop::toggleNumLockState() |
645 | { | 645 | { |
646 | tb->toggleNumLockState(); | 646 | tb->toggleNumLockState(); |
647 | } | 647 | } |
648 | 648 | ||
649 | void Desktop::toggleCapsLockState() | 649 | void Desktop::toggleCapsLockState() |
650 | { | 650 | { |
651 | tb->toggleCapsLockState(); | 651 | tb->toggleCapsLockState(); |
652 | } | 652 | } |
653 | 653 | ||
654 | void Desktop::styleChange( QStyle &s ) | 654 | void Desktop::styleChange( QStyle &s ) |
655 | { | 655 | { |
656 | QWidget::styleChange( s ); | 656 | QWidget::styleChange( s ); |
657 | int displayw = qApp->desktop()->width(); | 657 | int displayw = qApp->desktop()->width(); |
658 | int displayh = qApp->desktop()->height(); | 658 | int displayh = qApp->desktop()->height(); |
659 | 659 | ||
660 | QSize sz = tb->sizeHint(); | 660 | QSize sz = tb->sizeHint(); |
661 | 661 | ||
662 | tb->setGeometry( 0, displayh-sz.height(), displayw, sz.height() ); | 662 | tb->setGeometry( 0, displayh-sz.height(), displayw, sz.height() ); |
663 | } | 663 | } |
664 | 664 | ||
665 | void DesktopApplication::shutdown() | 665 | void DesktopApplication::shutdown() |
666 | { | 666 | { |
667 | if ( type() != GuiServer ) | 667 | if ( type() != GuiServer ) |
668 | return; | 668 | return; |
669 | ShutdownImpl *sd = new ShutdownImpl( 0, 0, WDestructiveClose ); | 669 | ShutdownImpl *sd = new ShutdownImpl( 0, 0, WDestructiveClose ); |
670 | connect( sd, SIGNAL(shutdown(ShutdownImpl::Type)), | 670 | connect( sd, SIGNAL(shutdown(ShutdownImpl::Type)), |
671 | this, SLOT(shutdown(ShutdownImpl::Type)) ); | 671 | this, SLOT(shutdown(ShutdownImpl::Type)) ); |
672 | sd->showMaximized(); | 672 | sd->showMaximized(); |
673 | } | 673 | } |
674 | 674 | ||
675 | void DesktopApplication::shutdown( ShutdownImpl::Type t ) | 675 | void DesktopApplication::shutdown( ShutdownImpl::Type t ) |
676 | { | 676 | { |
677 | switch ( t ) { | 677 | switch ( t ) { |
678 | case ShutdownImpl::ShutdownSystem: | 678 | case ShutdownImpl::ShutdownSystem: |
679 | execlp("shutdown", "shutdown", "-h", "now", (void*)0); | 679 | execlp("shutdown", "shutdown", "-h", "now", (void*)0); |
680 | break; | 680 | break; |
681 | case ShutdownImpl::RebootSystem: | 681 | case ShutdownImpl::RebootSystem: |
682 | execlp("shutdown", "shutdown", "-r", "now", (void*)0); | 682 | execlp("shutdown", "shutdown", "-r", "now", (void*)0); |
683 | break; | 683 | break; |
684 | case ShutdownImpl::RestartDesktop: | 684 | case ShutdownImpl::RestartDesktop: |
685 | restart(); | 685 | restart(); |
686 | break; | 686 | break; |
687 | case ShutdownImpl::TerminateDesktop: | 687 | case ShutdownImpl::TerminateDesktop: |
688 | prepareForTermination(FALSE); | 688 | prepareForTermination(FALSE); |
689 | |||
690 | // This is a workaround for a Qt bug | ||
691 | // clipboard applet has to stop its poll timer, or Qt/E | ||
692 | // will hang on quit() right before it emits aboutToQuit() | ||
693 | emit aboutToQuit ( ); | ||
694 | |||
689 | quit(); | 695 | quit(); |
690 | break; | 696 | break; |
691 | } | 697 | } |
692 | } | 698 | } |
693 | 699 | ||
694 | void DesktopApplication::restart() | 700 | void DesktopApplication::restart() |
695 | { | 701 | { |
696 | prepareForTermination(TRUE); | 702 | prepareForTermination(TRUE); |
697 | 703 | ||
698 | #ifdef Q_WS_QWS | 704 | #ifdef Q_WS_QWS |
699 | for ( int fd = 3; fd < 100; fd++ ) | 705 | for ( int fd = 3; fd < 100; fd++ ) |
700 | close( fd ); | 706 | close( fd ); |
701 | #if defined(QT_DEMO_SINGLE_FLOPPY) | 707 | #if defined(QT_DEMO_SINGLE_FLOPPY) |
702 | execl( "/sbin/init", "qpe", 0 ); | 708 | execl( "/sbin/init", "qpe", 0 ); |
703 | #elif defined(QT_QWS_CASSIOPEIA) | 709 | #elif defined(QT_QWS_CASSIOPEIA) |
704 | execl( "/bin/sh", "sh", 0 ); | 710 | execl( "/bin/sh", "sh", 0 ); |
705 | #else | 711 | #else |
706 | execl( (qpeDir()+"/bin/qpe").latin1(), "qpe", 0 ); | 712 | execl( (qpeDir()+"/bin/qpe").latin1(), "qpe", 0 ); |
707 | #endif | 713 | #endif |
708 | exit(1); | 714 | exit(1); |
709 | #endif | 715 | #endif |
710 | } | 716 | } |
711 | 717 | ||
712 | void Desktop::startTransferServer() | 718 | void Desktop::startTransferServer() |
713 | { | 719 | { |
714 | // start qcop bridge server | 720 | // start qcop bridge server |
715 | qcopBridge = new QCopBridge( 4243 ); | 721 | qcopBridge = new QCopBridge( 4243 ); |
716 | if ( !qcopBridge->ok() ) { | 722 | if ( !qcopBridge->ok() ) { |
717 | delete qcopBridge; | 723 | delete qcopBridge; |
718 | qcopBridge = 0; | 724 | qcopBridge = 0; |
719 | } | 725 | } |
720 | // start transfer server | 726 | // start transfer server |
721 | transferServer = new TransferServer( 4242 ); | 727 | transferServer = new TransferServer( 4242 ); |
722 | if ( !transferServer->ok() ) { | 728 | if ( !transferServer->ok() ) { |
723 | delete transferServer; | 729 | delete transferServer; |
724 | transferServer = 0; | 730 | transferServer = 0; |
725 | } | 731 | } |
726 | if ( !transferServer || !qcopBridge ) | 732 | if ( !transferServer || !qcopBridge ) |
727 | startTimer( 2000 ); | 733 | startTimer( 2000 ); |
728 | } | 734 | } |
729 | 735 | ||
730 | void Desktop::timerEvent( QTimerEvent *e ) | 736 | void Desktop::timerEvent( QTimerEvent *e ) |
731 | { | 737 | { |
732 | killTimer( e->timerId() ); | 738 | killTimer( e->timerId() ); |
733 | startTransferServer(); | 739 | startTransferServer(); |
734 | } | 740 | } |
735 | 741 | ||
736 | void Desktop::terminateServers() | 742 | void Desktop::terminateServers() |
737 | { | 743 | { |
738 | delete transferServer; | 744 | delete transferServer; |
739 | delete qcopBridge; | 745 | delete qcopBridge; |
740 | transferServer = 0; | 746 | transferServer = 0; |
741 | qcopBridge = 0; | 747 | qcopBridge = 0; |
742 | } | 748 | } |
743 | 749 | ||
744 | void Desktop::rereadVolumes() | 750 | void Desktop::rereadVolumes() |
745 | { | 751 | { |
746 | Config cfg("qpe"); | 752 | Config cfg("qpe"); |
747 | cfg.setGroup("Volume"); | 753 | cfg.setGroup("Volume"); |
748 | touchclick = cfg.readBoolEntry("TouchSound"); | 754 | touchclick = cfg.readBoolEntry("TouchSound"); |
749 | keyclick = cfg.readBoolEntry("KeySound"); | 755 | keyclick = cfg.readBoolEntry("KeySound"); |
750 | alarmsound = cfg.readBoolEntry("AlarmSound"); | 756 | alarmsound = cfg.readBoolEntry("AlarmSound"); |
751 | // Config cfg("Sound"); | 757 | // Config cfg("Sound"); |
752 | // cfg.setGroup("System"); | 758 | // cfg.setGroup("System"); |
753 | // touchclick = cfg.readBoolEntry("Touch"); | 759 | // touchclick = cfg.readBoolEntry("Touch"); |
754 | // keyclick = cfg.readBoolEntry("Key"); | 760 | // keyclick = cfg.readBoolEntry("Key"); |
755 | } | 761 | } |
756 | 762 | ||
757 | void Desktop::keyClick() | 763 | void Desktop::keyClick() |
758 | { | 764 | { |
759 | if ( keyclick ) | 765 | if ( keyclick ) |
760 | ODevice::inst ( )-> keySound ( ); | 766 | ODevice::inst ( )-> keySound ( ); |
761 | } | 767 | } |
762 | 768 | ||
763 | void Desktop::screenClick() | 769 | void Desktop::screenClick() |
764 | { | 770 | { |
765 | if ( touchclick ) | 771 | if ( touchclick ) |
766 | ODevice::inst ( )-> touchSound ( ); | 772 | ODevice::inst ( )-> touchSound ( ); |
767 | } | 773 | } |
768 | 774 | ||
769 | void Desktop::soundAlarm() | 775 | void Desktop::soundAlarm() |
770 | { | 776 | { |
771 | if ( qpedesktop-> alarmsound ) | 777 | if ( qpedesktop-> alarmsound ) |
772 | ODevice::inst ( )-> alarmSound ( ); | 778 | ODevice::inst ( )-> alarmSound ( ); |
773 | } | 779 | } |
774 | 780 | ||
775 | bool Desktop::eventFilter( QObject *, QEvent *ev ) | 781 | bool Desktop::eventFilter( QObject *, QEvent *ev ) |
776 | { | 782 | { |
777 | if ( ev-> type ( ) == QEvent::KeyPress ) { | 783 | if ( ev-> type ( ) == QEvent::KeyPress ) { |
778 | QKeyEvent *ke = (QKeyEvent *) ev; | 784 | QKeyEvent *ke = (QKeyEvent *) ev; |
779 | if ( ke-> key ( ) == Qt::Key_F11 ) { // menu key | 785 | if ( ke-> key ( ) == Qt::Key_F11 ) { // menu key |
780 | QWidget *active = qApp-> activeWindow ( ); | 786 | QWidget *active = qApp-> activeWindow ( ); |
781 | 787 | ||
782 | if ( active && active-> isPopup ( )) | 788 | if ( active && active-> isPopup ( )) |
783 | active->close(); | 789 | active->close(); |
784 | 790 | ||
785 | raiseMenu ( ); | 791 | raiseMenu ( ); |
786 | return true; | 792 | return true; |
787 | } | 793 | } |
788 | } | 794 | } |
789 | return false; | 795 | return false; |
790 | } | 796 | } |