summaryrefslogtreecommitdiff
authorar <ar>2004-05-02 14:59:14 (UTC)
committer ar <ar>2004-05-02 14:59:14 (UTC)
commit4e7ab937501b6495ce5635a7515e66a75e04d37e (patch) (unidiff)
tree6cecc2081d0a15a101b7fca0a7a61c6c992d73bc
parentbb9c5e1bbf2692dc9b669e5f573edcdd92615476 (diff)
downloadopie-4e7ab937501b6495ce5635a7515e66a75e04d37e.zip
opie-4e7ab937501b6495ce5635a7515e66a75e04d37e.tar.gz
opie-4e7ab937501b6495ce5635a7515e66a75e04d37e.tar.bz2
- convert qDebug to odebug
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/applets/cardmon/cardmon.cpp6
-rw-r--r--core/applets/vmemo/vmemo.cpp221
2 files changed, 112 insertions, 115 deletions
diff --git a/core/applets/cardmon/cardmon.cpp b/core/applets/cardmon/cardmon.cpp
index 3a6ad27..3af3d03 100644
--- a/core/applets/cardmon/cardmon.cpp
+++ b/core/applets/cardmon/cardmon.cpp
@@ -92,157 +92,155 @@ void CardMonitor::popUp( QString message, QString icon )
92 92
93 popupMenu->clear(); 93 popupMenu->clear();
94 if ( icon.isEmpty() ) 94 if ( icon.isEmpty() )
95 { 95 {
96 popupMenu->insertItem( message, 0 ); 96 popupMenu->insertItem( message, 0 );
97 } 97 }
98 else 98 else
99 { 99 {
100 popupMenu->insertItem( QIconSet( Resource::loadPixmap( icon ) ), 100 popupMenu->insertItem( QIconSet( Resource::loadPixmap( icon ) ),
101 message, 0 ); 101 message, 0 );
102 } 102 }
103 103
104 QPoint p = mapToGlobal( QPoint( 0, 0 ) ); 104 QPoint p = mapToGlobal( QPoint( 0, 0 ) );
105 QSize s = popupMenu->sizeHint(); 105 QSize s = popupMenu->sizeHint();
106 popupMenu->popup( QPoint( p.x() + ( width() / 2 ) - ( s.width() / 2 ), 106 popupMenu->popup( QPoint( p.x() + ( width() / 2 ) - ( s.width() / 2 ),
107 p.y() - s.height() ), 0 ); 107 p.y() - s.height() ), 0 );
108 108
109 QTimer::singleShot( 2000, this, SLOT( popupTimeout() ) ); 109 QTimer::singleShot( 2000, this, SLOT( popupTimeout() ) );
110} 110}
111 111
112void CardMonitor::popupTimeout() 112void CardMonitor::popupTimeout()
113{ 113{
114 popupMenu->hide(); 114 popupMenu->hide();
115} 115}
116 116
117void CardMonitor::mousePressEvent( QMouseEvent * ) 117void CardMonitor::mousePressEvent( QMouseEvent * )
118{ 118{
119 QPopupMenu * menu = new QPopupMenu( this ); 119 QPopupMenu * menu = new QPopupMenu( this );
120 QString cmd; 120 QString cmd;
121 int err = 0; 121 int err = 0;
122 122
123 if ( cardInSd ) 123 if ( cardInSd )
124 { 124 {
125 menu->insertItem( QIconSet( Resource::loadPixmap( "cardmon/ide" ) ), 125 menu->insertItem( QIconSet( Resource::loadPixmap( "cardmon/ide" ) ),
126 tr( "Eject SD/MMC card" ), 0 ); 126 tr( "Eject SD/MMC card" ), 0 );
127 } 127 }
128 128
129 if ( cardInPcmcia0 ) 129 if ( cardInPcmcia0 )
130 { 130 {
131 menu-> 131 menu->
132 insertItem( QIconSet 132 insertItem( QIconSet
133 ( Resource::loadPixmap( "cardmon/" + cardInPcmcia0Type ) ), 133 ( Resource::loadPixmap( "cardmon/" + cardInPcmcia0Type ) ),
134 tr( "Eject card 0: %1" ).arg( cardInPcmcia0Name ), 1 ); 134 tr( "Eject card 0: %1" ).arg( cardInPcmcia0Name ), 1 );
135 } 135 }
136 136
137 if ( cardInPcmcia1 ) 137 if ( cardInPcmcia1 )
138 { 138 {
139 menu-> 139 menu->
140 insertItem( QIconSet 140 insertItem( QIconSet
141 ( Resource::loadPixmap( "cardmon/" + cardInPcmcia1Type ) ), 141 ( Resource::loadPixmap( "cardmon/" + cardInPcmcia1Type ) ),
142 tr( "Eject card 1: %1" ).arg( cardInPcmcia1Name ), 2 ); 142 tr( "Eject card 1: %1" ).arg( cardInPcmcia1Name ), 2 );
143 } 143 }
144 144
145 QPoint p = mapToGlobal( QPoint( 0, 0 ) ); 145 QPoint p = mapToGlobal( QPoint( 0, 0 ) );
146 QSize s = menu->sizeHint(); 146 QSize s = menu->sizeHint();
147 int opt = menu->exec( QPoint( p.x() + ( width() / 2 ) - ( s.width() / 2 ), 147 int opt = menu->exec( QPoint( p.x() + ( width() / 2 ) - ( s.width() / 2 ),
148 p.y() - s.height() ), 0 ); 148 p.y() - s.height() ), 0 );
149 149
150 if ( opt == 1 ) 150 if ( opt == 1 )
151 { 151 {
152 cmd = "/sbin/cardctl eject 0"; 152 cmd = "/sbin/cardctl eject 0";
153 err = system( ( const char * ) cmd ); 153 err = system( ( const char * ) cmd );
154 if ( err != 0 ) 154 if ( err != 0 )
155 { 155 {
156 qDebug( "Could not execute `/sbin/cardctl eject 0'! err=%d", 156 odebug << "Could not execute `/sbin/cardctl eject 0'! err=" << err << oendl;
157 err );
158 popUp( tr( "CF/PCMCIA card eject failed!" ) ); 157 popUp( tr( "CF/PCMCIA card eject failed!" ) );
159 } 158 }
160 } 159 }
161 else if ( opt == 0 ) 160 else if ( opt == 0 )
162 { 161 {
163 if ( ODevice::inst() ->system() == System_Familiar ) 162 if ( ODevice::inst() ->system() == System_Familiar )
164 { 163 {
165 cmd = "umount /dev/mmc/part1"; 164 cmd = "umount /dev/mmc/part1";
166 } 165 }
167 else 166 else
168 { 167 {
169 cmd = "umount /dev/mmcda1"; 168 cmd = "umount /dev/mmcda1";
170 } 169 }
171 err = system( ( const char * ) cmd ); 170 err = system( ( const char * ) cmd );
172 if ( err != 0 ) 171 if ( err != 0 )
173 { 172 {
174 popUp( tr( "SD/MMC card eject failed!" ) ); 173 popUp( tr( "SD/MMC card eject failed!" ) );
175 } 174 }
176 } 175 }
177 else if ( opt == 2 ) 176 else if ( opt == 2 )
178 { 177 {
179 cmd = "/sbin/cardctl eject 1"; 178 cmd = "/sbin/cardctl eject 1";
180 err = system( ( const char * ) cmd ); 179 err = system( ( const char * ) cmd );
181 if ( err != 0 ) 180 if ( err != 0 )
182 { 181 {
183 qDebug( "Could not execute `/sbin/cardctl eject 1'! err=%d", 182 odebug << "Could not execute `/sbin/cardctl eject 1'! err=" << err << oendl;
184 err );
185 popUp( tr( "CF/PCMCIA card eject failed!" ) ); 183 popUp( tr( "CF/PCMCIA card eject failed!" ) );
186 } 184 }
187 } 185 }
188 delete menu; 186 delete menu;
189} 187}
190 188
191 189
192void CardMonitor::cardMessage( const QCString & msg, const QByteArray & ) 190void CardMonitor::cardMessage( const QCString & msg, const QByteArray & )
193{ 191{
194 if ( msg == "stabChanged()" ) 192 if ( msg == "stabChanged()" )
195 { 193 {
196 // odebug << "Pcmcia: stabchanged" << oendl; 194 // odebug << "Pcmcia: stabchanged" << oendl;
197 getStatusPcmcia(); 195 getStatusPcmcia();
198 } 196 }
199 else if ( msg == "mtabChanged()" ) 197 else if ( msg == "mtabChanged()" )
200 { 198 {
201 // odebug << "CARDMONAPPLET: mtabchanged" << oendl; 199 // odebug << "CARDMONAPPLET: mtabchanged" << oendl;
202 getStatusSd(); 200 getStatusSd();
203 } 201 }
204} 202}
205 203
206bool CardMonitor::getStatusPcmcia( int showPopUp ) 204bool CardMonitor::getStatusPcmcia( int showPopUp )
207{ 205{
208 206
209 bool cardWas0 = cardInPcmcia0; // remember last state 207 bool cardWas0 = cardInPcmcia0; // remember last state
210 bool cardWas1 = cardInPcmcia1; 208 bool cardWas1 = cardInPcmcia1;
211 209
212 QString fileName; 210 QString fileName;
213 211
214 // one of these 3 files should exist 212 // one of these 3 files should exist
215 if ( QFile::exists( "/var/run/stab" ) ) 213 if ( QFile::exists( "/var/run/stab" ) )
216 { 214 {
217 fileName = "/var/run/stab"; 215 fileName = "/var/run/stab";
218 } 216 }
219 else if ( QFile::exists( "/var/state/pcmcia/stab" ) ) 217 else if ( QFile::exists( "/var/state/pcmcia/stab" ) )
220 { 218 {
221 fileName = "/var/state/pcmcia/stab"; 219 fileName = "/var/state/pcmcia/stab";
222 } 220 }
223 else 221 else
224 { 222 {
225 fileName = "/var/lib/pcmcia/stab"; 223 fileName = "/var/lib/pcmcia/stab";
226 } 224 }
227 225
228 QFile f( fileName ); 226 QFile f( fileName );
229 227
230 if ( f.open( IO_ReadOnly ) ) 228 if ( f.open( IO_ReadOnly ) )
231 { 229 {
232 QStringList list; 230 QStringList list;
233 QTextStream stream( &f ); 231 QTextStream stream( &f );
234 QString streamIn; 232 QString streamIn;
235 streamIn = stream.read(); 233 streamIn = stream.read();
236 list = QStringList::split( "\n", streamIn ); 234 list = QStringList::split( "\n", streamIn );
237 for ( QStringList::Iterator line = list.begin(); line != list.end(); 235 for ( QStringList::Iterator line = list.begin(); line != list.end();
238 line++ ) 236 line++ )
239 { 237 {
240 if ( ( *line ).startsWith( "Socket 0:" ) ) 238 if ( ( *line ).startsWith( "Socket 0:" ) )
241 { 239 {
242 if ( ( *line ).startsWith( "Socket 0: empty" ) && cardInPcmcia0 ) 240 if ( ( *line ).startsWith( "Socket 0: empty" ) && cardInPcmcia0 )
243 { 241 {
244 cardInPcmcia0 = FALSE; 242 cardInPcmcia0 = FALSE;
245 } 243 }
246 else if ( !( *line ).startsWith( "Socket 0: empty" ) 244 else if ( !( *line ).startsWith( "Socket 0: empty" )
247 && !cardInPcmcia0 ) 245 && !cardInPcmcia0 )
248 { 246 {
diff --git a/core/applets/vmemo/vmemo.cpp b/core/applets/vmemo/vmemo.cpp
index 835f63a..f088bef 100644
--- a/core/applets/vmemo/vmemo.cpp
+++ b/core/applets/vmemo/vmemo.cpp
@@ -162,129 +162,129 @@ static char * vmemo_xpm[] = {
162 "R c #3B3C40", 162 "R c #3B3C40",
163 "S c #6E6E74", 163 "S c #6E6E74",
164 "T c #95959C", 164 "T c #95959C",
165 "U c #74747A", 165 "U c #74747A",
166 "V c #1D1D1E", 166 "V c #1D1D1E",
167 "W c #91929A", 167 "W c #91929A",
168 "X c #42444A", 168 "X c #42444A",
169 "Y c #22282E", 169 "Y c #22282E",
170 "Z c #B0B2BC", 170 "Z c #B0B2BC",
171 "` c #898A90", 171 "` c #898A90",
172 " . c #65656A", 172 " . c #65656A",
173 ".. c #999AA2", 173 ".. c #999AA2",
174 "+. c #52535A", 174 "+. c #52535A",
175 "@. c #151B21", 175 "@. c #151B21",
176 "#. c #515257", 176 "#. c #515257",
177 "$. c #B5B5BE", 177 "$. c #B5B5BE",
178 "%. c #616167", 178 "%. c #616167",
179 "&. c #1A1D22", 179 "&. c #1A1D22",
180 "*. c #000713", 180 "*. c #000713",
181 "=. c #1F1F21", 181 "=. c #1F1F21",
182 " ", 182 " ",
183 " . + @ # ", 183 " . + @ # ",
184 " $ % & * = - ", 184 " $ % & * = - ",
185 " ; > , ' ) ! ~ ", 185 " ; > , ' ) ! ~ ",
186 " { ] ^ / ( _ : ", 186 " { ] ^ / ( _ : ",
187 " < [ } | 1 2 3 ", 187 " < [ } | 1 2 3 ",
188 " 4 5 6 7 8 9 0 a b c ", 188 " 4 5 6 7 8 9 0 a b c ",
189 " d e f g h i j 3 k l m n ", 189 " d e f g h i j 3 k l m n ",
190 " o p q r s t u v w n ", 190 " o p q r s t u v w n ",
191 " o x y z A B C D E n ", 191 " o x y z A B C D E n ",
192 " F G H I J K L M N O ", 192 " F G H I J K L M N O ",
193 " P Q R S T U V W X ", 193 " P Q R S T U V W X ",
194 " Y Z ` b ...+. ", 194 " Y Z ` b ...+. ",
195 " @.#.$.%.&. ", 195 " @.#.$.%.&. ",
196 " *.B =. ", 196 " *.B =. ",
197 " n n n n n n n n n "}; 197 " n n n n n n n n n "};
198 198
199 199
200using namespace Opie::Ui; 200using namespace Opie::Ui;
201VMemo::VMemo( QWidget *parent, const char *_name ) 201VMemo::VMemo( QWidget *parent, const char *_name )
202 : QWidget( parent, _name ) { 202 : QWidget( parent, _name ) {
203 setFixedHeight( 18 ); 203 setFixedHeight( 18 );
204 setFixedWidth( 14 ); 204 setFixedWidth( 14 );
205 205
206 t_timer = new QTimer( this ); 206 t_timer = new QTimer( this );
207 connect( t_timer, SIGNAL( timeout() ), SLOT( timerBreak() ) ); 207 connect( t_timer, SIGNAL( timeout() ), SLOT( timerBreak() ) );
208 208
209 Config vmCfg("Vmemo"); 209 Config vmCfg("Vmemo");
210 vmCfg.setGroup("Defaults"); 210 vmCfg.setGroup("Defaults");
211 int toggleKey = setToggleButton(vmCfg.readNumEntry("toggleKey", -1)); 211 int toggleKey = setToggleButton(vmCfg.readNumEntry("toggleKey", -1));
212 useADPCM = vmCfg.readBoolEntry("use_ADPCM", 0); 212 useADPCM = vmCfg.readBoolEntry("use_ADPCM", 0);
213 213
214 odebug << "toggleKey " << toggleKey << "" << oendl; 214 odebug << "toggleKey " << toggleKey << "" << oendl;
215 215
216// if ( QFile::exists ( "/dev/sharp_buz" ) || QFile::exists ( "/dev/sharp_led" )) 216// if ( QFile::exists ( "/dev/sharp_buz" ) || QFile::exists ( "/dev/sharp_led" ))
217// systemZaurus=TRUE; 217// systemZaurus=TRUE;
218// else 218// else
219 systemZaurus = FALSE; 219 systemZaurus = FALSE;
220 220
221 myChannel = new QCopChannel( "QPE/VMemo", this ); 221 myChannel = new QCopChannel( "QPE/VMemo", this );
222 connect( myChannel, SIGNAL(received(const QCString&,const QByteArray&)), 222 connect( myChannel, SIGNAL(received(const QCString&,const QByteArray&)),
223 this, SLOT(receive(const QCString&,const QByteArray&)) ); 223 this, SLOT(receive(const QCString&,const QByteArray&)) );
224 224
225 if( toggleKey != -1 ) { 225 if( toggleKey != -1 ) {
226 qDebug("Register key %d", toggleKey); 226 odebug << "Register key " << toggleKey << "" << oendl;
227 QCopEnvelope e("QPE/Launcher", "keyRegister(int,QCString,QCString)"); 227 QCopEnvelope e("QPE/Launcher", "keyRegister(int,QCString,QCString)");
228 // e << 4096; // Key_Escape 228 // e << 4096; // Key_Escape
229 // e << Key_F5; //4148 229 // e << Key_F5; //4148
230 e << toggleKey; 230 e << toggleKey;
231 e << QString("QPE/VMemo"); 231 e << QString("QPE/VMemo");
232 e << QString("toggleRecord()"); 232 e << QString("toggleRecord()");
233 } 233 }
234 if(toggleKey == 1) 234 if(toggleKey == 1)
235 usingIcon = TRUE; 235 usingIcon = TRUE;
236 else 236 else
237 usingIcon = FALSE; 237 usingIcon = FALSE;
238// if( vmCfg.readNumEntry("hideIcon",0) == 1) 238// if( vmCfg.readNumEntry("hideIcon",0) == 1)
239// hide(); 239// hide();
240 recording = FALSE; 240 recording = FALSE;
241 // } 241 // }
242} 242}
243 243
244VMemo::~VMemo() { 244VMemo::~VMemo() {
245} 245}
246 246
247int VMemo::position() 247int VMemo::position()
248{ 248{
249 return 6; 249 return 6;
250} 250}
251 251
252void VMemo::receive( const QCString &msg, const QByteArray &data ) { 252void VMemo::receive( const QCString &msg, const QByteArray &data ) {
253 odebug << "Vmemo receive" << oendl; 253 odebug << "Vmemo receive" << oendl;
254 QDataStream stream( data, IO_ReadOnly ); 254 QDataStream stream( data, IO_ReadOnly );
255 255
256 if (msg == "toggleRecord()") { 256 if (msg == "toggleRecord()") {
257 if (recording) { 257 if (recording) {
258 fromToggle = TRUE; 258 fromToggle = TRUE;
259 stopRecording(); 259 stopRecording();
260 } else { 260 } else {
261 fromToggle = TRUE; 261 fromToggle = TRUE;
262 startRecording(); 262 startRecording();
263 } 263 }
264 } 264 }
265} 265}
266 266
267void VMemo::paintEvent( QPaintEvent* ) { 267void VMemo::paintEvent( QPaintEvent* ) {
268 QPainter p(this); 268 QPainter p(this);
269 p.drawPixmap( 0, 1,( const char** ) vmemo_xpm ); 269 p.drawPixmap( 0, 1,( const char** ) vmemo_xpm );
270} 270}
271 271
272void VMemo::mousePressEvent( QMouseEvent * /*me*/) { 272void VMemo::mousePressEvent( QMouseEvent * /*me*/) {
273 /* No mousePress/mouseRelease recording on the iPAQ. The REC button on the iPAQ calls these functions 273 /* No mousePress/mouseRelease recording on the iPAQ. The REC button on the iPAQ calls these functions
274 mousePressEvent and mouseReleaseEvent with a NULL parameter. */ 274 mousePressEvent and mouseReleaseEvent with a NULL parameter. */
275 275
276// if (!systemZaurus && me != NULL) 276// if (!systemZaurus && me != NULL)
277// return; 277// return;
278// } 278// }
279 279
280 if(!recording) 280 if(!recording)
281 startRecording(); 281 startRecording();
282 else 282 else
283 stopRecording(); 283 stopRecording();
284} 284}
285 285
286void VMemo::mouseReleaseEvent( QMouseEvent * ) { 286void VMemo::mouseReleaseEvent( QMouseEvent * ) {
287} 287}
288 288
289bool VMemo::startRecording() { 289bool VMemo::startRecording() {
290 Config config( "Vmemo" ); 290 Config config( "Vmemo" );
@@ -415,242 +415,241 @@ int VMemo::openDSP() {
415 415
416 if(dsp == -1) { 416 if(dsp == -1) {
417 msgLabel->close(); 417 msgLabel->close();
418 msgLabel=0; 418 msgLabel=0;
419 delete msgLabel; 419 delete msgLabel;
420 420
421 perror("open(\"/dev/dsp\")"); 421 perror("open(\"/dev/dsp\")");
422 errorMsg="open(\"/dev/dsp\")\n "+(QString)strerror(errno); 422 errorMsg="open(\"/dev/dsp\")\n "+(QString)strerror(errno);
423 QMessageBox::critical(0, "vmemo", errorMsg, "Abort"); 423 QMessageBox::critical(0, "vmemo", errorMsg, "Abort");
424 return -1; 424 return -1;
425 } 425 }
426 426
427 if(ioctl(dsp, SNDCTL_DSP_SETFMT , &format)==-1) { 427 if(ioctl(dsp, SNDCTL_DSP_SETFMT , &format)==-1) {
428 perror("ioctl(\"SNDCTL_DSP_SETFMT\")"); 428 perror("ioctl(\"SNDCTL_DSP_SETFMT\")");
429 return -1; 429 return -1;
430 } 430 }
431 if(ioctl(dsp, SNDCTL_DSP_CHANNELS , &channels)==-1) { 431 if(ioctl(dsp, SNDCTL_DSP_CHANNELS , &channels)==-1) {
432 perror("ioctl(\"SNDCTL_DSP_CHANNELS\")"); 432 perror("ioctl(\"SNDCTL_DSP_CHANNELS\")");
433 return -1; 433 return -1;
434 } 434 }
435 if(ioctl(dsp, SNDCTL_DSP_SPEED , &speed)==-1) { 435 if(ioctl(dsp, SNDCTL_DSP_SPEED , &speed)==-1) {
436 perror("ioctl(\"SNDCTL_DSP_SPEED\")"); 436 perror("ioctl(\"SNDCTL_DSP_SPEED\")");
437 return -1; 437 return -1;
438 } 438 }
439 if(ioctl(dsp, SOUND_PCM_READ_RATE , &rate)==-1) { 439 if(ioctl(dsp, SOUND_PCM_READ_RATE , &rate)==-1) {
440 perror("ioctl(\"SOUND_PCM_READ_RATE\")"); 440 perror("ioctl(\"SOUND_PCM_READ_RATE\")");
441 return -1; 441 return -1;
442 } 442 }
443 443
444 QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << FALSE; //mute 444 QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << FALSE; //mute
445 445
446 return 1; 446 return 1;
447} 447}
448 448
449int VMemo::openWAV(const char *filename) { 449int VMemo::openWAV(const char *filename) {
450 track.setName(filename); 450 track.setName(filename);
451 if(!track.open(IO_WriteOnly|IO_Truncate|IO_Raw)) { 451 if(!track.open(IO_WriteOnly|IO_Truncate|IO_Raw)) {
452 errorMsg=filename; 452 errorMsg=filename;
453 return -1; 453 return -1;
454 } 454 }
455 455
456 wav=track.handle(); 456 wav=track.handle();
457 Config vmCfg("Vmemo"); 457 Config vmCfg("Vmemo");
458 vmCfg.setGroup("Defaults"); 458 vmCfg.setGroup("Defaults");
459 useADPCM = vmCfg.readBoolEntry("use_ADPCM", 0); 459 useADPCM = vmCfg.readBoolEntry("use_ADPCM", 0);
460 460
461 WaveHeader wh; 461 WaveHeader wh;
462 462
463 wh.main_chunk = RIFF; 463 wh.main_chunk = RIFF;
464 wh.length=0; 464 wh.length=0;
465 wh.chunk_type = WAVE; 465 wh.chunk_type = WAVE;
466 wh.sub_chunk = FMT; 466 wh.sub_chunk = FMT;
467 wh.sc_len = 16; 467 wh.sc_len = 16;
468 if(useADPCM) 468 if(useADPCM)
469 wh.format = WAVE_FORMAT_DVI_ADPCM;//PCM_CODE; 469 wh.format = WAVE_FORMAT_DVI_ADPCM;//PCM_CODE;
470 else 470 else
471 wh.format = PCM_CODE; 471 wh.format = PCM_CODE;
472 wh.modus = channels; 472 wh.modus = channels;
473 wh.sample_fq = speed; 473 wh.sample_fq = speed;
474 wh.byte_p_sec = speed * channels * resolution/8; 474 wh.byte_p_sec = speed * channels * resolution/8;
475 wh.byte_p_spl = channels * (resolution / 8); 475 wh.byte_p_spl = channels * (resolution / 8);
476 wh.bit_p_spl = resolution; 476 wh.bit_p_spl = resolution;
477 wh.data_chunk = DATA; 477 wh.data_chunk = DATA;
478 wh.data_length= 0; 478 wh.data_length= 0;
479 // qDebug("Write header channels %d, speed %d, b/s %d, blockalign %d, bitrate %d" 479 // odebug << "Write header channels " << wh.modus << ", speed " << wh.sample_fq << ", b/s "
480 // , wh.modus, wh.sample_fq, wh.byte_p_sec, wh.byte_p_spl, wh.bit_p_spl ); 480 // << wh.byte_p_sec << ", blockalign " << wh.byte_p_spl << ", bitrate " << wh.bit_p_spl << oendl;
481 write (wav, &wh, sizeof(WaveHeader)); 481 write (wav, &wh, sizeof(WaveHeader));
482 482
483 return 1; 483 return 1;
484} 484}
485 485
486bool VMemo::record() { 486bool VMemo::record() {
487 length = 0; 487 length = 0;
488 int bytesWritten = 0; 488 int bytesWritten = 0;
489 int result = 0; 489 int result = 0;
490 int value = 0; 490 int value = 0;
491 QString msg; 491 QString msg;
492 msg.sprintf("Recording format %d", format); 492 msg.sprintf("Recording format %d", format);
493 odebug << msg << oendl; 493 odebug << msg << oendl;
494 Config config("Vmemo"); 494 Config config("Vmemo");
495 config.setGroup("Record"); 495 config.setGroup("Record");
496 int sRate = config.readNumEntry("SizeLimit", 30); 496 int sRate = config.readNumEntry("SizeLimit", 30);
497 if(sRate > 0) 497 if(sRate > 0)
498 t_timer->start( sRate * 1000+1000, TRUE); 498 t_timer->start( sRate * 1000+1000, TRUE);
499 499
500 msg.sprintf("Recording format other"); 500 msg.sprintf("Recording format other");
501 odebug << msg << oendl; 501 odebug << msg << oendl;
502 502
503 config.setGroup("Defaults"); 503 config.setGroup("Defaults");
504 useADPCM = config.readBoolEntry("use_ADPCM", 0); 504 useADPCM = config.readBoolEntry("use_ADPCM", 0);
505 505
506 int bufsize = config.readNumEntry("BufferSize",1024); 506 int bufsize = config.readNumEntry("BufferSize",1024);
507 unsigned short sound[bufsize]; //, monoBuffer[bufsize]; 507 unsigned short sound[bufsize]; //, monoBuffer[bufsize];
508 char abuf[bufsize / 2]; 508 char abuf[bufsize / 2];
509 short sbuf[bufsize]; 509 short sbuf[bufsize];
510 510
511 if(useADPCM) { 511 if(useADPCM) {
512 while(recording) { 512 while(recording) {
513 result = ::read(dsp, sbuf, bufsize); // adpcm read 513 result = ::read(dsp, sbuf, bufsize); // adpcm read
514 if( result <= 0) { 514 if( result <= 0) {
515 perror("recording error "); 515 perror("recording error ");
516 QMessageBox::message(tr("Note"),tr("error recording")); 516 QMessageBox::message(tr("Note"),tr("error recording"));
517 recording = FALSE; 517 recording = FALSE;
518 break; 518 break;
519 return FALSE; 519 return FALSE;
520 } 520 }
521 adpcm_coder( sbuf, abuf, result/2, &encoder_state); 521 adpcm_coder( sbuf, abuf, result/2, &encoder_state);
522 bytesWritten = ::write(wav, abuf, result/4); // adpcm write 522 bytesWritten = ::write(wav, abuf, result/4); // adpcm write
523 length += bytesWritten; 523 length += bytesWritten;
524 524
525 if(length < 0) { 525 if(length < 0) {
526 recording = false; 526 recording = false;
527 perror("dev/dsp's is a lookin' messy"); 527 perror("dev/dsp's is a lookin' messy");
528 QMessageBox::message("Vmemo","Error writing to file\n"+ fileName); 528 QMessageBox::message("Vmemo","Error writing to file\n"+ fileName);
529 break; 529 break;
530 return FALSE; 530 return FALSE;
531 } 531 }
532 // printf("%d\r", length); 532 // printf("%d\r", length);
533 // fflush(stdout); 533 // fflush(stdout);
534 qApp->processEvents(); 534 qApp->processEvents();
535 } 535 }
536 } else { 536 } else {
537 while(recording) { 537 while(recording) {
538 result = ::read(dsp, sound, bufsize); // read 538 result = ::read(dsp, sound, bufsize); // read
539 if( result <= 0) { 539 if( result <= 0) {
540 perror("recording error "); 540 perror("recording error ");
541 QMessageBox::message(tr("Note"),tr("error recording")); 541 QMessageBox::message(tr("Note"),tr("error recording"));
542 recording = FALSE; 542 recording = FALSE;
543 break; 543 break;
544 return FALSE; 544 return FALSE;
545 545
546 bytesWritten = ::write(wav, sound, result); // write 546 bytesWritten = ::write(wav, sound, result); // write
547 length += bytesWritten; 547 length += bytesWritten;
548 548
549 if(length < 0) { 549 if(length < 0) {
550 recording = false; 550 recording = false;
551 perror("dev/dsp's is a lookin' messy"); 551 perror("dev/dsp's is a lookin' messy");
552 QMessageBox::message("Vmemo","Error writing to file\n"+ fileName); 552 QMessageBox::message("Vmemo","Error writing to file\n"+ fileName);
553 break; 553 break;
554 return FALSE; 554 return FALSE;
555 } 555 }
556 // printf("%d\r", length); 556 // printf("%d\r", length);
557 // fflush(stdout); 557 // fflush(stdout);
558 qApp->processEvents(); 558 qApp->processEvents();
559 } 559 }
560 } 560 }
561 } 561 }
562 // qDebug("file has length of %d lasting %d seconds", 562 // odebug << "file has length of " << length << " lasting " << (( length / speed) / channels) / 2 ) << " seconds" << oendl;
563 // length, (( length / speed) / channels) / 2 ); 563
564 564 value = length + 36;
565 value = length + 36; 565
566 566 lseek(wav, 4, SEEK_SET);
567 lseek(wav, 4, SEEK_SET); 567 write(wav, &value, 4);
568 write(wav, &value, 4); 568 lseek(wav, 40, SEEK_SET);
569 lseek(wav, 40, SEEK_SET); 569
570 570 write(wav, &length, 4);
571 write(wav, &length, 4); 571
572 572 track.close();
573 track.close(); 573 odebug << "Track closed" << oendl;
574 odebug << "Track closed" << oendl; 574
575 575 if( ioctl( dsp, SNDCTL_DSP_RESET,0) == -1)
576 if( ioctl( dsp, SNDCTL_DSP_RESET,0) == -1) 576 perror("ioctl(\"SNDCTL_DSP_RESET\")");
577 perror("ioctl(\"SNDCTL_DSP_RESET\")"); 577
578 578 ::close(dsp);
579 ::close(dsp); 579
580 580 Config cfgO("OpieRec");
581 Config cfgO("OpieRec"); 581 cfgO.setGroup("Sounds");
582 cfgO.setGroup("Sounds"); 582
583 583 int nFiles = cfgO.readNumEntry( "NumberofFiles",0);
584 int nFiles = cfgO.readNumEntry( "NumberofFiles",0); 584
585 585 QString currentFileName = fileName;
586 QString currentFileName = fileName; 586 QString currentFile = "vm_"+ date;
587 QString currentFile = "vm_"+ date; 587
588 588 float numberOfRecordedSeconds = (float) length / (float)speed * (float)2;
589 float numberOfRecordedSeconds = (float) length / (float)speed * (float)2; 589
590 590 cfgO.writeEntry( "NumberofFiles", nFiles + 1);
591 cfgO.writeEntry( "NumberofFiles", nFiles + 1); 591 cfgO.writeEntry( QString::number( nFiles + 1), currentFile);
592 cfgO.writeEntry( QString::number( nFiles + 1), currentFile); 592 cfgO.writeEntry( currentFile, currentFileName);
593 cfgO.writeEntry( currentFile, currentFileName); 593
594 594 QString time;
595 QString time; 595 time.sprintf("%.2f", numberOfRecordedSeconds);
596 time.sprintf("%.2f", numberOfRecordedSeconds); 596 cfgO.writeEntry( currentFileName, time );
597 cfgO.writeEntry( currentFileName, time );
598 // odebug << "writing config numberOfRecordedSeconds "+time << oendl; 597 // odebug << "writing config numberOfRecordedSeconds "+time << oendl;
599 598
600 cfgO.write(); 599 cfgO.write();
601 600
602 odebug << "done recording "+fileName << oendl; 601 odebug << "done recording "+fileName << oendl;
603 602
604 Config cfg("qpe"); 603 Config cfg("qpe");
605 cfg.setGroup("Volume"); 604 cfg.setGroup("Volume");
606 QString foo = cfg.readEntry("Mute","TRUE"); 605 QString foo = cfg.readEntry("Mute","TRUE");
607 if(foo.find("TRUE",0,TRUE) != -1) 606 if(foo.find("TRUE",0,TRUE) != -1)
608 QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << TRUE; //mute 607 QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << TRUE; //mute
609 return TRUE; 608 return TRUE;
610} 609}
611 610
612int VMemo::setToggleButton(int tog) { 611int VMemo::setToggleButton(int tog) {
613 612
614 for( int i=0; i < 10;i++) { 613 for( int i=0; i < 10;i++) {
615 switch (tog) { 614 switch (tog) {
616 case 0: 615 case 0:
617 return -1; 616 return -1;
618 break; 617 break;
619 case 1: 618 case 1:
620 return 0; 619 return 0;
621 break; 620 break;
622 case 2: 621 case 2:
623 return Key_F24; //was Escape 622 return Key_F24; //was Escape
624 break; 623 break;
625 case 3: 624 case 3:
626 return Key_Space; 625 return Key_Space;
627 break; 626 break;
628 case 4: 627 case 4:
629 return Key_F12; 628 return Key_F12;
630 break; 629 break;
631 case 5: 630 case 5:
632 return Key_F9; 631 return Key_F9;
633 break; 632 break;
634 case 6: 633 case 6:
635 return Key_F10; 634 return Key_F10;
636 break; 635 break;
637 case 7: 636 case 7:
638 return Key_F11; 637 return Key_F11;
639 break; 638 break;
640 case 8: 639 case 8:
641 return Key_F13; 640 return Key_F13;
642 break; 641 break;
643 }; 642 };
644 } 643 }
645 return -1; 644 return -1;
646} 645}
647 646
648void VMemo::timerBreak() { 647void VMemo::timerBreak() {
649 //stop 648 //stop
650 stopRecording(); 649 stopRecording();
651 QMessageBox::message("Vmemo","Vmemo recording has ended"); 650 QMessageBox::message("Vmemo","Vmemo recording has ended");
652} 651}
653 652
654 653
655EXPORT_OPIE_APPLET_v1( VMemo ) 654EXPORT_OPIE_APPLET_v1( VMemo )
656 655