summaryrefslogtreecommitdiff
authorsandman <sandman>2002-08-28 23:18:58 (UTC)
committer sandman <sandman>2002-08-28 23:18:58 (UTC)
commit178bd471d12a88862fb4ac1a17842ea0fd63c160 (patch) (unidiff)
treec37b10465eca3b6c2431b7999fe32eb4692f12ee
parent186bdeb08c0d9ccd78177310cf9f69ea80b76a96 (diff)
downloadopie-178bd471d12a88862fb4ac1a17842ea0fd63c160.zip
opie-178bd471d12a88862fb4ac1a17842ea0fd63c160.tar.gz
opie-178bd471d12a88862fb4ac1a17842ea0fd63c160.tar.bz2
Workaround for a possible race condition in the QWS server (mostly OZ)
(clipboard handling in Qt/E is a mess)
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/applets/clipboardapplet/clipboard.cpp17
1 files changed, 15 insertions, 2 deletions
diff --git a/core/applets/clipboardapplet/clipboard.cpp b/core/applets/clipboardapplet/clipboard.cpp
index 4fbdf6f..3099a84 100644
--- a/core/applets/clipboardapplet/clipboard.cpp
+++ b/core/applets/clipboardapplet/clipboard.cpp
@@ -3,240 +3,253 @@
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 */
35static const char * paste_xpm[] = { 35static 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
119ClipboardApplet::ClipboardApplet( QWidget *parent, const char *name ) : QWidget( parent, name ) 119ClipboardApplet::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 m_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 ( m_timer, SIGNAL( timeout ( )), this, SLOT( newData ( ))); 128 connect ( m_timer, SIGNAL( timeout ( )), this, SLOT( newData ( )));
129 connect ( qApp, SIGNAL( aboutToQuit ( )), this, SLOT( shutdown ( ))); 129 connect ( qApp, SIGNAL( aboutToQuit ( )), this, SLOT( shutdown ( )));
130 130
131 m_timer-> start ( 1500 );
132
133 m_menu = 0; 131 m_menu = 0;
134 m_dirty = true; 132 m_dirty = true;
135 m_lasttext = QString::null; 133 m_lasttext = QString::null;
134
135 m_timer-> start ( 0, true );
136} 136}
137 137
138ClipboardApplet::~ClipboardApplet ( ) 138ClipboardApplet::~ClipboardApplet ( )
139{ 139{
140} 140}
141 141
142void ClipboardApplet::shutdown ( ) 142void ClipboardApplet::shutdown ( )
143{ 143{
144 // the timer has to be stopped, or Qt/E will hang on quit() 144 // the timer has to be stopped, or Qt/E will hang on quit()
145 // see launcher/desktop.cpp 145 // see launcher/desktop.cpp
146 146
147 m_timer-> stop ( ); 147 m_timer-> stop ( );
148} 148}
149 149
150void ClipboardApplet::mousePressEvent ( QMouseEvent *) 150void ClipboardApplet::mousePressEvent ( QMouseEvent *)
151{ 151{
152 if ( m_dirty ) { 152 if ( m_dirty ) {
153 delete m_menu; 153 delete m_menu;
154 154
155 m_menu = new QPopupMenu ( this ); 155 m_menu = new QPopupMenu ( this );
156 m_menu-> setCheckable ( true ); 156 m_menu-> setCheckable ( true );
157 157
158 if ( m_history. count ( )) { 158 if ( m_history. count ( )) {
159 for ( unsigned int i = 0; i < m_history. count ( ); i++ ) { 159 for ( unsigned int i = 0; i < m_history. count ( ); i++ ) {
160 QString str = m_history [i]; 160 QString str = m_history [i];
161 161
162 if ( str. length ( ) > 20 ) 162 if ( str. length ( ) > 20 )
163 str = str. left ( 20 ) + "..."; 163 str = str. left ( 20 ) + "...";
164 164
165 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 );
166 m_menu-> setItemChecked ( i, false ); 166 m_menu-> setItemChecked ( i, false );
167 } 167 }
168 m_menu-> setItemChecked ( m_history. count ( ) - 1, true ); 168 m_menu-> setItemChecked ( m_history. count ( ) - 1, true );
169 m_menu-> insertSeparator ( ); 169 m_menu-> insertSeparator ( );
170 } 170 }
171 m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "cut" )), tr( "Cut" ), 100 ); 171 m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "cut" )), tr( "Cut" ), 100 );
172 m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "copy" )), tr( "Copy" ), 101 ); 172 m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "copy" )), tr( "Copy" ), 101 );
173 m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "paste" )), tr( "Paste" ), 102 ); 173 m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "paste" )), tr( "Paste" ), 102 );
174 174
175 connect ( m_menu, SIGNAL( activated ( int )), this, SLOT( action ( int ))); 175 connect ( m_menu, SIGNAL( activated ( int )), this, SLOT( action ( int )));
176 176
177 m_dirty = false; 177 m_dirty = false;
178 } 178 }
179 QPoint p = mapToGlobal ( QPoint ( 0, 0 )); 179 QPoint p = mapToGlobal ( QPoint ( 0, 0 ));
180 QSize s = m_menu-> sizeHint ( ); 180 QSize s = m_menu-> sizeHint ( );
181 181
182 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 ( )));
183} 183}
184 184
185void ClipboardApplet::action(int id) 185void ClipboardApplet::action(int id)
186{ 186{
187 ushort unicode = 0; 187 ushort unicode = 0;
188 int scan = 0; 188 int scan = 0;
189 189
190 switch ( id ) { 190 switch ( id ) {
191 case 100: 191 case 100:
192 unicode = 'X' - '@'; 192 unicode = 'X' - '@';
193 scan = Key_X; // Cut 193 scan = Key_X; // Cut
194 break; 194 break;
195 case 101: 195 case 101:
196 unicode = 'C' - '@'; 196 unicode = 'C' - '@';
197 scan = Key_C; // Copy 197 scan = Key_C; // Copy
198 break; 198 break;
199 case 102: 199 case 102:
200 unicode = 'V' - '@'; 200 unicode = 'V' - '@';
201 scan = Key_V; // Paste 201 scan = Key_V; // Paste
202 break; 202 break;
203 203
204 default: 204 default:
205 if (( id >= 0 ) && ( uint( id ) < m_history. count ( ))) { 205 if (( id >= 0 ) && ( uint( id ) < m_history. count ( ))) {
206 QApplication::clipboard ( )-> setText ( m_history [id] ); 206 QApplication::clipboard ( )-> setText ( m_history [id] );
207 207
208 for ( uint i = 0; i < m_history. count ( ); i++ ) 208 for ( uint i = 0; i < m_history. count ( ); i++ )
209 m_menu-> setItemChecked ( i, i == uint( id )); 209 m_menu-> setItemChecked ( i, i == uint( id ));
210 210
211 unicode = 'V' - '@'; 211 unicode = 'V' - '@';
212 scan = Key_V; 212 scan = Key_V;
213 } 213 }
214 break; 214 break;
215 } 215 }
216 216
217 if ( scan ) { 217 if ( scan ) {
218 qwsServer-> sendKeyEvent ( unicode, scan, ControlButton, true, false ); 218 qwsServer-> sendKeyEvent ( unicode, scan, ControlButton, true, false );
219 qwsServer-> sendKeyEvent ( unicode, scan, ControlButton, false, false ); 219 qwsServer-> sendKeyEvent ( unicode, scan, ControlButton, false, false );
220 } 220 }
221} 221}
222 222
223void ClipboardApplet::paintEvent ( QPaintEvent* ) 223void ClipboardApplet::paintEvent ( QPaintEvent* )
224{ 224{
225 QPainter p ( this ); 225 QPainter p ( this );
226 p. drawPixmap ( 0, 1, m_clipboardPixmap ); 226 p. drawPixmap ( 0, 1, m_clipboardPixmap );
227} 227}
228 228
229void ClipboardApplet::newData ( ) 229void ClipboardApplet::newData ( )
230{ 230{
231 static bool excllock = false;
232
233 if ( excllock )
234 return;
235 else
236 excllock = true;
237
238 m_timer-> stop ( );
239
231 QCString type = "plain"; 240 QCString type = "plain";
232 QString txt = QApplication::clipboard ( )-> text ( type ); 241 QString txt = QApplication::clipboard ( )-> text ( type );
233 242
234 if ( !txt. isEmpty ( ) && !m_history. contains ( txt )) { 243 if ( !txt. isEmpty ( ) && !m_history. contains ( txt )) {
235 m_history. append ( txt ); 244 m_history. append ( txt );
236 245
237 if ( m_history. count ( ) > 5 ) 246 if ( m_history. count ( ) > 5 )
238 m_history. remove ( m_history. begin ( )); 247 m_history. remove ( m_history. begin ( ));
239 248
240 m_dirty = true; 249 m_dirty = true;
241 } 250 }
251
252 m_timer-> start ( 1500, true );
253
254 excllock = false;
242} 255}