summaryrefslogtreecommitdiff
authormickeyl <mickeyl>2004-10-29 12:29:09 (UTC)
committer mickeyl <mickeyl>2004-10-29 12:29:09 (UTC)
commit464bf3433f6602bcf7f83342f0539bac8677ae64 (patch) (unidiff)
tree92fde973dd1a08ad45d8e950b645c3eae250be16
parent1cde6419bcf60ec1ba23750106b2ec01474416fb (diff)
downloadopie-464bf3433f6602bcf7f83342f0539bac8677ae64.zip
opie-464bf3433f6602bcf7f83342f0539bac8677ae64.tar.gz
opie-464bf3433f6602bcf7f83342f0539bac8677ae64.tar.bz2
smooth scale to proper icon size
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/applets/cardmon/cardmon.cpp5
1 files changed, 3 insertions, 2 deletions
diff --git a/core/applets/cardmon/cardmon.cpp b/core/applets/cardmon/cardmon.cpp
index d6ac616..53497df 100644
--- a/core/applets/cardmon/cardmon.cpp
+++ b/core/applets/cardmon/cardmon.cpp
@@ -1,380 +1,381 @@
1/* 1/*
2* cardmon.cpp 2* cardmon.cpp
3* 3*
4* --------------------- 4* ---------------------
5* 5*
6* copyright : (c) 2002 by Maximilian Reiss 6* copyright : (c) 2002 by Maximilian Reiss
7* email : max.reiss@gmx.de 7* email : max.reiss@gmx.de
8* based on two apps by Devin Butterfield 8* based on two apps by Devin Butterfield
9*/ 9*/
10/*************************************************************************** 10/***************************************************************************
11 * * 11 * *
12 * This program is free software; you can redistribute it and/or modify * 12 * This program is free software; you can redistribute it and/or modify *
13 * it under the terms of the GNU General Public License as published by * 13 * it under the terms of the GNU General Public License as published by *
14 * the Free Software Foundation; either version 2 of the License, or * 14 * the Free Software Foundation; either version 2 of the License, or *
15 * (at your option) any later version. * 15 * (at your option) any later version. *
16 * * 16 * *
17 ***************************************************************************/ 17 ***************************************************************************/
18 18
19#include "cardmon.h" 19#include "cardmon.h"
20 20
21/* OPIE */ 21/* OPIE */
22#include <opie2/odebug.h> 22#include <opie2/odebug.h>
23#include <opie2/odevice.h> 23#include <opie2/odevice.h>
24#include <opie2/otaskbarapplet.h> 24#include <opie2/otaskbarapplet.h>
25#include <opie2/oprocess.h> 25#include <opie2/oprocess.h>
26 26
27#include <qpe/applnk.h> 27#include <qpe/applnk.h>
28#include <qpe/resource.h> 28#include <qpe/resource.h>
29using namespace Opie::Core; 29using namespace Opie::Core;
30using namespace Opie::Ui; 30using namespace Opie::Ui;
31 31
32/* QT */ 32/* QT */
33#include <qcopchannel_qws.h> 33#include <qcopchannel_qws.h>
34#include <qpainter.h> 34#include <qpainter.h>
35#include <qfile.h> 35#include <qfile.h>
36#include <qtextstream.h> 36#include <qtextstream.h>
37#include <qsound.h> 37#include <qsound.h>
38#include <qtimer.h> 38#include <qtimer.h>
39 39
40/* STD */ 40/* STD */
41#include <stdio.h> 41#include <stdio.h>
42#include <unistd.h> 42#include <unistd.h>
43#include <stdlib.h> 43#include <stdlib.h>
44#include <string.h> 44#include <string.h>
45#include <fcntl.h> 45#include <fcntl.h>
46#if defined(_OS_LINUX_) || defined(Q_OS_LINUX) 46#if defined(_OS_LINUX_) || defined(Q_OS_LINUX)
47#include <sys/vfs.h> 47#include <sys/vfs.h>
48#include <mntent.h> 48#include <mntent.h>
49#endif 49#endif
50 50
51CardMonitor::CardMonitor( QWidget * parent ) : QWidget( parent ), 51CardMonitor::CardMonitor( QWidget * parent ) : QWidget( parent )
52pm( Resource::loadPixmap( "cardmon/pcmcia" ) ) { 52{
53 pm = Resource::loadImage( "cardmon/pcmcia").smoothScale(AppLnk::smallIconSize(), AppLnk::smallIconSize());
53 54
54 QCopChannel * pcmciaChannel = new QCopChannel( "QPE/Card", this ); 55 QCopChannel * pcmciaChannel = new QCopChannel( "QPE/Card", this );
55 connect( pcmciaChannel, 56 connect( pcmciaChannel,
56 SIGNAL( received(const QCString&,const QByteArray&) ), this, 57 SIGNAL( received(const QCString&,const QByteArray&) ), this,
57 SLOT( cardMessage(const QCString&,const QByteArray&) ) ); 58 SLOT( cardMessage(const QCString&,const QByteArray&) ) );
58 59
59 QCopChannel *sdChannel = new QCopChannel( "QPE/Card", this ); 60 QCopChannel *sdChannel = new QCopChannel( "QPE/Card", this );
60 connect( sdChannel, 61 connect( sdChannel,
61 SIGNAL( received(const QCString&,const QByteArray&) ), this, 62 SIGNAL( received(const QCString&,const QByteArray&) ), this,
62 SLOT( cardMessage(const QCString&,const QByteArray&) ) ); 63 SLOT( cardMessage(const QCString&,const QByteArray&) ) );
63 64
64 cardInPcmcia0 = FALSE; 65 cardInPcmcia0 = FALSE;
65 cardInPcmcia1 = FALSE; 66 cardInPcmcia1 = FALSE;
66 cardInSd = FALSE; 67 cardInSd = FALSE;
67 m_process = 0; 68 m_process = 0;
68 69
69 setFocusPolicy( NoFocus ); 70 setFocusPolicy( NoFocus );
70 71
71 setFixedWidth ( AppLnk::smallIconSize() ); 72 setFixedWidth ( AppLnk::smallIconSize() );
72 setFixedHeight ( AppLnk::smallIconSize() ); 73 setFixedHeight ( AppLnk::smallIconSize() );
73 74
74 getStatusPcmcia( TRUE ); 75 getStatusPcmcia( TRUE );
75 getStatusSd( TRUE ); 76 getStatusSd( TRUE );
76 repaint( FALSE ); 77 repaint( FALSE );
77 popupMenu = 0; 78 popupMenu = 0;
78} 79}
79 80
80CardMonitor::~CardMonitor() { 81CardMonitor::~CardMonitor() {
81 delete popupMenu; 82 delete popupMenu;
82} 83}
83 84
84void CardMonitor::popUp( QString message, QString icon ) { 85void CardMonitor::popUp( QString message, QString icon ) {
85 if ( !popupMenu ) { 86 if ( !popupMenu ) {
86 popupMenu = new QPopupMenu( this ); 87 popupMenu = new QPopupMenu( this );
87 } 88 }
88 89
89 popupMenu->clear(); 90 popupMenu->clear();
90 if ( icon.isEmpty() ) { 91 if ( icon.isEmpty() ) {
91 popupMenu->insertItem( message, 0 ); 92 popupMenu->insertItem( message, 0 );
92 } else { 93 } else {
93 popupMenu->insertItem( QIconSet( Resource::loadPixmap( icon ) ), 94 popupMenu->insertItem( QIconSet( Resource::loadPixmap( icon ) ),
94 message, 0 ); 95 message, 0 );
95 } 96 }
96 97
97 QPoint p = mapToGlobal( QPoint( 0, 0 ) ); 98 QPoint p = mapToGlobal( QPoint( 0, 0 ) );
98 QSize s = popupMenu->sizeHint(); 99 QSize s = popupMenu->sizeHint();
99 popupMenu->popup( QPoint( p.x() + ( width() / 2 ) - ( s.width() / 2 ), 100 popupMenu->popup( QPoint( p.x() + ( width() / 2 ) - ( s.width() / 2 ),
100 p.y() - s.height() ), 0 ); 101 p.y() - s.height() ), 0 );
101 102
102 QTimer::singleShot( 2000, this, SLOT( popupTimeout() ) ); 103 QTimer::singleShot( 2000, this, SLOT( popupTimeout() ) );
103} 104}
104 105
105void CardMonitor::popupTimeout() { 106void CardMonitor::popupTimeout() {
106 popupMenu->hide(); 107 popupMenu->hide();
107} 108}
108 109
109void CardMonitor::mousePressEvent( QMouseEvent * ) { 110void CardMonitor::mousePressEvent( QMouseEvent * ) {
110 QPopupMenu * menu = new QPopupMenu( this ); 111 QPopupMenu * menu = new QPopupMenu( this );
111 QStringList cmd; 112 QStringList cmd;
112 bool execute = true; 113 bool execute = true;
113 114
114 if ( cardInSd ) { 115 if ( cardInSd ) {
115 menu->insertItem( QIconSet( Resource::loadPixmap( "cardmon/ide" ) ), 116 menu->insertItem( QIconSet( Resource::loadPixmap( "cardmon/ide" ) ),
116 tr( "Eject SD/MMC card" ), 0 ); 117 tr( "Eject SD/MMC card" ), 0 );
117 } 118 }
118 119
119 if ( cardInPcmcia0 ) { 120 if ( cardInPcmcia0 ) {
120 menu-> 121 menu->
121 insertItem( QIconSet 122 insertItem( QIconSet
122 ( Resource::loadPixmap( "cardmon/" + cardInPcmcia0Type ) ), 123 ( Resource::loadPixmap( "cardmon/" + cardInPcmcia0Type ) ),
123 tr( "Eject card 0: %1" ).arg( cardInPcmcia0Name ), 1 ); 124 tr( "Eject card 0: %1" ).arg( cardInPcmcia0Name ), 1 );
124 } 125 }
125 126
126 if ( cardInPcmcia1 ) { 127 if ( cardInPcmcia1 ) {
127 menu-> 128 menu->
128 insertItem( QIconSet 129 insertItem( QIconSet
129 ( Resource::loadPixmap( "cardmon/" + cardInPcmcia1Type ) ), 130 ( Resource::loadPixmap( "cardmon/" + cardInPcmcia1Type ) ),
130 tr( "Eject card 1: %1" ).arg( cardInPcmcia1Name ), 2 ); 131 tr( "Eject card 1: %1" ).arg( cardInPcmcia1Name ), 2 );
131 } 132 }
132 133
133 QPoint p = mapToGlobal( QPoint( 0, 0 ) ); 134 QPoint p = mapToGlobal( QPoint( 0, 0 ) );
134 QSize s = menu->sizeHint(); 135 QSize s = menu->sizeHint();
135 int opt = menu->exec( QPoint( p.x() + ( width() / 2 ) - ( s.width() / 2 ), 136 int opt = menu->exec( QPoint( p.x() + ( width() / 2 ) - ( s.width() / 2 ),
136 p.y() - s.height() ), 0 ); 137 p.y() - s.height() ), 0 );
137 138
138 if ( opt == 1 ) { 139 if ( opt == 1 ) {
139 m_commandOrig = PCMCIA_Socket1; 140 m_commandOrig = PCMCIA_Socket1;
140 cmd << "/sbin/cardctl" << "eject" << "0"; 141 cmd << "/sbin/cardctl" << "eject" << "0";
141 } else if ( opt == 0 ) { 142 } else if ( opt == 0 ) {
142 m_commandOrig = MMC_Socket; 143 m_commandOrig = MMC_Socket;
143 cmd << "umount" << cardSdName; 144 cmd << "umount" << cardSdName;
144 } else if ( opt == 2 ) { 145 } else if ( opt == 2 ) {
145 m_commandOrig = PCMCIA_Socket2; 146 m_commandOrig = PCMCIA_Socket2;
146 cmd << "/sbin/cardctl" << "eject" << "1"; 147 cmd << "/sbin/cardctl" << "eject" << "1";
147 }else 148 }else
148 execute = false; 149 execute = false;
149 150
150 if ( execute ) 151 if ( execute )
151 execCommand( cmd ); 152 execCommand( cmd );
152 153
153 delete menu; 154 delete menu;
154} 155}
155 156
156 157
157void CardMonitor::cardMessage( const QCString & msg, const QByteArray & ) { 158void CardMonitor::cardMessage( const QCString & msg, const QByteArray & ) {
158 if ( msg == "stabChanged()" ) { 159 if ( msg == "stabChanged()" ) {
159 // odebug << "Pcmcia: stabchanged" << oendl; 160 // odebug << "Pcmcia: stabchanged" << oendl;
160 getStatusPcmcia(); 161 getStatusPcmcia();
161 } else if ( msg == "mtabChanged()" ) { 162 } else if ( msg == "mtabChanged()" ) {
162 // odebug << "CARDMONAPPLET: mtabchanged" << oendl; 163 // odebug << "CARDMONAPPLET: mtabchanged" << oendl;
163 getStatusSd(); 164 getStatusSd();
164 } 165 }
165} 166}
166 167
167bool CardMonitor::getStatusPcmcia( int showPopUp ) { 168bool CardMonitor::getStatusPcmcia( int showPopUp ) {
168 169
169 bool cardWas0 = cardInPcmcia0; // remember last state 170 bool cardWas0 = cardInPcmcia0; // remember last state
170 bool cardWas1 = cardInPcmcia1; 171 bool cardWas1 = cardInPcmcia1;
171 172
172 QString fileName; 173 QString fileName;
173 174
174 // one of these 3 files should exist 175 // one of these 3 files should exist
175 if ( QFile::exists( "/var/run/stab" ) ) { 176 if ( QFile::exists( "/var/run/stab" ) ) {
176 fileName = "/var/run/stab"; 177 fileName = "/var/run/stab";
177 } else if ( QFile::exists( "/var/state/pcmcia/stab" ) ) { 178 } else if ( QFile::exists( "/var/state/pcmcia/stab" ) ) {
178 fileName = "/var/state/pcmcia/stab"; 179 fileName = "/var/state/pcmcia/stab";
179 } else { 180 } else {
180 fileName = "/var/lib/pcmcia/stab"; 181 fileName = "/var/lib/pcmcia/stab";
181 } 182 }
182 183
183 QFile f( fileName ); 184 QFile f( fileName );
184 185
185 if ( f.open( IO_ReadOnly ) ) { 186 if ( f.open( IO_ReadOnly ) ) {
186 QStringList list; 187 QStringList list;
187 QTextStream stream( &f ); 188 QTextStream stream( &f );
188 QString streamIn; 189 QString streamIn;
189 streamIn = stream.read(); 190 streamIn = stream.read();
190 list = QStringList::split( "\n", streamIn ); 191 list = QStringList::split( "\n", streamIn );
191 for ( QStringList::Iterator line = list.begin(); line != list.end(); 192 for ( QStringList::Iterator line = list.begin(); line != list.end();
192 line++ ) { 193 line++ ) {
193 if ( ( *line ).startsWith( "Socket 0:" ) ) { 194 if ( ( *line ).startsWith( "Socket 0:" ) ) {
194 if ( ( *line ).startsWith( "Socket 0: empty" ) && cardInPcmcia0 ) { 195 if ( ( *line ).startsWith( "Socket 0: empty" ) && cardInPcmcia0 ) {
195 cardInPcmcia0 = FALSE; 196 cardInPcmcia0 = FALSE;
196 } else if ( !( *line ).startsWith( "Socket 0: empty" ) 197 } else if ( !( *line ).startsWith( "Socket 0: empty" )
197 && !cardInPcmcia0 ) { 198 && !cardInPcmcia0 ) {
198 cardInPcmcia0Name = 199 cardInPcmcia0Name =
199 ( *line ).mid( ( ( *line ).find( ':' ) + 1 ), 200 ( *line ).mid( ( ( *line ).find( ':' ) + 1 ),
200 ( *line ).length() - 9 ); 201 ( *line ).length() - 9 );
201 cardInPcmcia0Name.stripWhiteSpace(); 202 cardInPcmcia0Name.stripWhiteSpace();
202 cardInPcmcia0 = TRUE; 203 cardInPcmcia0 = TRUE;
203 show(); 204 show();
204 line++; 205 line++;
205 int pos = ( *line ).find( '\t' ) + 1; 206 int pos = ( *line ).find( '\t' ) + 1;
206 cardInPcmcia0Type = 207 cardInPcmcia0Type =
207 ( *line ).mid( pos, ( *line ).find( "\t", pos ) - pos ); 208 ( *line ).mid( pos, ( *line ).find( "\t", pos ) - pos );
208 } 209 }
209 } else if ( ( *line ).startsWith( "Socket 1:" ) ) { 210 } else if ( ( *line ).startsWith( "Socket 1:" ) ) {
210 if ( ( *line ).startsWith( "Socket 1: empty" ) && cardInPcmcia1 ) { 211 if ( ( *line ).startsWith( "Socket 1: empty" ) && cardInPcmcia1 ) {
211 cardInPcmcia1 = FALSE; 212 cardInPcmcia1 = FALSE;
212 } else if ( !( *line ).startsWith( "Socket 1: empty" ) 213 } else if ( !( *line ).startsWith( "Socket 1: empty" )
213 && !cardInPcmcia1 ) { 214 && !cardInPcmcia1 ) {
214 cardInPcmcia1Name = 215 cardInPcmcia1Name =
215 ( *line ).mid( ( ( *line ).find( ':' ) + 1 ), 216 ( *line ).mid( ( ( *line ).find( ':' ) + 1 ),
216 ( *line ).length() - 9 ); 217 ( *line ).length() - 9 );
217 cardInPcmcia1Name.stripWhiteSpace(); 218 cardInPcmcia1Name.stripWhiteSpace();
218 cardInPcmcia1 = TRUE; 219 cardInPcmcia1 = TRUE;
219 show(); 220 show();
220 line++; 221 line++;
221 int pos = ( *line ).find( '\t' ) + 1; 222 int pos = ( *line ).find( '\t' ) + 1;
222 cardInPcmcia1Type = 223 cardInPcmcia1Type =
223 ( *line ).mid( pos, ( *line ).find( "\t", pos ) - pos ); 224 ( *line ).mid( pos, ( *line ).find( "\t", pos ) - pos );
224 } 225 }
225 } 226 }
226 } 227 }
227 f.close(); 228 f.close();
228 229
229 if ( !showPopUp 230 if ( !showPopUp
230 && ( cardWas0 != cardInPcmcia0 || cardWas1 != cardInPcmcia1 ) ) { 231 && ( cardWas0 != cardInPcmcia0 || cardWas1 != cardInPcmcia1 ) ) {
231 QString text = QString::null; 232 QString text = QString::null;
232 QString what = QString::null; 233 QString what = QString::null;
233 if ( cardWas0 != cardInPcmcia0 ) { 234 if ( cardWas0 != cardInPcmcia0 ) {
234 if ( cardInPcmcia0 ) { 235 if ( cardInPcmcia0 ) {
235 text += tr( "New card: " ); 236 text += tr( "New card: " );
236 what = "on"; 237 what = "on";
237 } else { 238 } else {
238 text += tr( "Ejected: " ); 239 text += tr( "Ejected: " );
239 what = "off"; 240 what = "off";
240 } 241 }
241 text += cardInPcmcia0Name; 242 text += cardInPcmcia0Name;
242 popUp( text, "cardmon/" + cardInPcmcia0Type ); 243 popUp( text, "cardmon/" + cardInPcmcia0Type );
243 } 244 }
244 245
245 if ( cardWas1 != cardInPcmcia1 ) { 246 if ( cardWas1 != cardInPcmcia1 ) {
246 if ( cardInPcmcia1 ) { 247 if ( cardInPcmcia1 ) {
247 text += tr( "New card: " ); 248 text += tr( "New card: " );
248 what = "on"; 249 what = "on";
249 } else { 250 } else {
250 text += tr( "Ejected: " ); 251 text += tr( "Ejected: " );
251 what = "off"; 252 what = "off";
252 } 253 }
253 text += cardInPcmcia1Name; 254 text += cardInPcmcia1Name;
254 popUp( text, "cardmon/" + cardInPcmcia1Type ); 255 popUp( text, "cardmon/" + cardInPcmcia1Type );
255 } 256 }
256 #ifndef QT_NO_SOUND 257 #ifndef QT_NO_SOUND
257 QSound::play( Resource::findSound( "cardmon/card" + what ) ); 258 QSound::play( Resource::findSound( "cardmon/card" + what ) );
258 #endif 259 #endif
259 260
260 } 261 }
261 } else { 262 } else {
262 // no file found 263 // no file found
263 odebug << "no file found" << oendl; 264 odebug << "no file found" << oendl;
264 cardInPcmcia0 = FALSE; 265 cardInPcmcia0 = FALSE;
265 cardInPcmcia1 = FALSE; 266 cardInPcmcia1 = FALSE;
266 } 267 }
267 repaint( FALSE ); 268 repaint( FALSE );
268 return ( ( cardWas0 == cardInPcmcia0 269 return ( ( cardWas0 == cardInPcmcia0
269 && cardWas1 == cardInPcmcia1 ) ? FALSE : TRUE ); 270 && cardWas1 == cardInPcmcia1 ) ? FALSE : TRUE );
270 271
271} 272}
272 273
273 274
274bool CardMonitor::getStatusSd( int showPopUp ) { 275bool CardMonitor::getStatusSd( int showPopUp ) {
275 276
276 bool cardWas = cardInSd; // remember last state 277 bool cardWas = cardInSd; // remember last state
277 cardInSd = FALSE; 278 cardInSd = FALSE;
278 279
279 #if defined(_OS_LINUX_) || defined(Q_OS_LINUX) 280 #if defined(_OS_LINUX_) || defined(Q_OS_LINUX)
280 281
281 struct mntent *me; 282 struct mntent *me;
282 FILE *mntfp = setmntent( "/etc/mtab", "r" ); 283 FILE *mntfp = setmntent( "/etc/mtab", "r" );
283 284
284 if ( mntfp ) { 285 if ( mntfp ) {
285 while ( ( me = getmntent( mntfp ) ) != 0 ) { 286 while ( ( me = getmntent( mntfp ) ) != 0 ) {
286 QString fs = QFile::decodeName( me->mnt_fsname ); 287 QString fs = QFile::decodeName( me->mnt_fsname );
287 //odebug << fs << oendl; 288 //odebug << fs << oendl;
288 if ( fs.left( 14 ) == "/dev/mmc/part1" || fs.left( 7 ) == "/dev/sd" 289 if ( fs.left( 14 ) == "/dev/mmc/part1" || fs.left( 7 ) == "/dev/sd"
289 || fs.left( 9 ) == "/dev/mmcd" ) { 290 || fs.left( 9 ) == "/dev/mmcd" ) {
290 cardInSd = TRUE; 291 cardInSd = TRUE;
291 cardSdName = fs; 292 cardSdName = fs;
292 show(); 293 show();
293 } 294 }
294 // else { 295 // else {
295 // cardInSd = FALSE; 296 // cardInSd = FALSE;
296 // } 297 // }
297 } 298 }
298 endmntent( mntfp ); 299 endmntent( mntfp );
299 } 300 }
300 301
301 if ( !showPopUp && cardWas != cardInSd ) { 302 if ( !showPopUp && cardWas != cardInSd ) {
302 QString text = QString::null; 303 QString text = QString::null;
303 QString what = QString::null; 304 QString what = QString::null;
304 if ( cardInSd ) { 305 if ( cardInSd ) {
305 text += tr("New card: SD/MMC"); 306 text += tr("New card: SD/MMC");
306 what = "on"; 307 what = "on";
307 } else { 308 } else {
308 text += tr("Ejected: SD/MMC"); 309 text += tr("Ejected: SD/MMC");
309 what = "off"; 310 what = "off";
310 } 311 }
311 //odebug << "TEXT: " + text << oendl; 312 //odebug << "TEXT: " + text << oendl;
312 #ifndef QT_NO_SOUND 313 #ifndef QT_NO_SOUND
313 QSound::play( Resource::findSound( "cardmon/card" + what ) ); 314 QSound::play( Resource::findSound( "cardmon/card" + what ) );
314 #endif 315 #endif
315 316
316 popUp( text, "cardmon/ide" ); // XX add SD pic 317 popUp( text, "cardmon/ide" ); // XX add SD pic
317 } 318 }
318 #else 319 #else
319 #error "Not on Linux" 320 #error "Not on Linux"
320 #endif 321 #endif
321 repaint( FALSE ); 322 repaint( FALSE );
322 return ( ( cardWas == cardInSd ) ? FALSE : TRUE ); 323 return ( ( cardWas == cardInSd ) ? FALSE : TRUE );
323} 324}
324 325
325void CardMonitor::paintEvent( QPaintEvent * ) { 326void CardMonitor::paintEvent( QPaintEvent * ) {
326 327
327 QPainter p( this ); 328 QPainter p( this );
328 329
329 if ( cardInPcmcia0 || cardInPcmcia1 || cardInSd ) { 330 if ( cardInPcmcia0 || cardInPcmcia1 || cardInSd ) {
330 p.drawPixmap( 0, 0, pm ); 331 p.drawPixmap( 0, 0, pm );
331 show(); 332 show();
332 } else { 333 } else {
333 //p.eraseRect(rect()); 334 //p.eraseRect(rect());
334 hide(); 335 hide();
335 } 336 }
336} 337}
337 338
338int CardMonitor::position() { 339int CardMonitor::position() {
339 return 7; 340 return 7;
340} 341}
341 342
342void CardMonitor::execCommand( const QStringList &strList ) { 343void CardMonitor::execCommand( const QStringList &strList ) {
343 delete m_process; 344 delete m_process;
344 m_process = 0; 345 m_process = 0;
345 346
346 if ( m_process == 0 ) { 347 if ( m_process == 0 ) {
347 m_process = new OProcess(); 348 m_process = new OProcess();
348 349
349 350
350 for ( QStringList::ConstIterator it = strList.begin(); it != strList.end(); ++it ) { 351 for ( QStringList::ConstIterator it = strList.begin(); it != strList.end(); ++it ) {
351 *m_process << *it; 352 *m_process << *it;
352 } 353 }
353 354
354 connect(m_process, SIGNAL(processExited(Opie::Core::OProcess*)), 355 connect(m_process, SIGNAL(processExited(Opie::Core::OProcess*)),
355 this, SLOT( slotExited(Opie::Core::OProcess*))); 356 this, SLOT( slotExited(Opie::Core::OProcess*)));
356 357
357 if(!m_process->start(OProcess::NotifyOnExit, OProcess::AllOutput ) ) { 358 if(!m_process->start(OProcess::NotifyOnExit, OProcess::AllOutput ) ) {
358 delete m_process; 359 delete m_process;
359 m_process = 0; 360 m_process = 0;
360 } 361 }
361 } 362 }
362} 363}
363 364
364void CardMonitor::slotExited( OProcess* ) { 365void CardMonitor::slotExited( OProcess* ) {
365 366
366 if( m_process->normalExit() ) { 367 if( m_process->normalExit() ) {
367 int ret = m_process->exitStatus(); 368 int ret = m_process->exitStatus();
368 if( ret != 0 ) { 369 if( ret != 0 ) {
369 if ( m_commandOrig == PCMCIA_Socket1 || 370 if ( m_commandOrig == PCMCIA_Socket1 ||
370 m_commandOrig == PCMCIA_Socket2 ) { 371 m_commandOrig == PCMCIA_Socket2 ) {
371 popUp( tr( "CF/PCMCIA card eject failed!" ) ); 372 popUp( tr( "CF/PCMCIA card eject failed!" ) );
372 } else if ( m_commandOrig == MMC_Socket ) { 373 } else if ( m_commandOrig == MMC_Socket ) {
373 popUp( tr( "SD/MMC card eject failed!" ) ); 374 popUp( tr( "SD/MMC card eject failed!" ) );
374 } 375 }
375 } 376 }
376 } 377 }
377} 378}
378 379
379EXPORT_OPIE_APPLET_v1( CardMonitor ) 380EXPORT_OPIE_APPLET_v1( CardMonitor )
380 381