summaryrefslogtreecommitdiff
authorllornkcor <llornkcor>2002-07-29 12:22:11 (UTC)
committer llornkcor <llornkcor>2002-07-29 12:22:11 (UTC)
commit0868e96b1737d121733c898ae92348a279e5b53f (patch) (unidiff)
treeb0fd8451d06776994528f3aa3b561fccbd053151
parentb4827a8b268af9d1485455cdf727f564047f396e (diff)
downloadopie-0868e96b1737d121733c898ae92348a279e5b53f.zip
opie-0868e96b1737d121733c898ae92348a279e5b53f.tar.gz
opie-0868e96b1737d121733c898ae92348a279e5b53f.tar.bz2
fix bug number 140
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/applets/vmemo/vmemo.cpp1
1 files changed, 1 insertions, 0 deletions
diff --git a/core/applets/vmemo/vmemo.cpp b/core/applets/vmemo/vmemo.cpp
index 0c792c6..577db75 100644
--- a/core/applets/vmemo/vmemo.cpp
+++ b/core/applets/vmemo/vmemo.cpp
@@ -177,384 +177,385 @@ static char * vmemo_xpm[] = {
177 "X c #42444A", 177 "X c #42444A",
178 "Y c #22282E", 178 "Y c #22282E",
179 "Z c #B0B2BC", 179 "Z c #B0B2BC",
180 "` c #898A90", 180 "` c #898A90",
181 " . c #65656A", 181 " . c #65656A",
182 ".. c #999AA2", 182 ".. c #999AA2",
183 "+. c #52535A", 183 "+. c #52535A",
184 "@. c #151B21", 184 "@. c #151B21",
185 "#. c #515257", 185 "#. c #515257",
186 "$. c #B5B5BE", 186 "$. c #B5B5BE",
187 "%. c #616167", 187 "%. c #616167",
188 "&. c #1A1D22", 188 "&. c #1A1D22",
189 "*. c #000713", 189 "*. c #000713",
190 "=. c #1F1F21", 190 "=. c #1F1F21",
191 " ", 191 " ",
192 " . + @ # ", 192 " . + @ # ",
193 " $ % & * = - ", 193 " $ % & * = - ",
194 " ; > , ' ) ! ~ ", 194 " ; > , ' ) ! ~ ",
195 " { ] ^ / ( _ : ", 195 " { ] ^ / ( _ : ",
196 " < [ } | 1 2 3 ", 196 " < [ } | 1 2 3 ",
197 " 4 5 6 7 8 9 0 a b c ", 197 " 4 5 6 7 8 9 0 a b c ",
198 " d e f g h i j 3 k l m n ", 198 " d e f g h i j 3 k l m n ",
199 " o p q r s t u v w n ", 199 " o p q r s t u v w n ",
200 " o x y z A B C D E n ", 200 " o x y z A B C D E n ",
201 " F G H I J K L M N O ", 201 " F G H I J K L M N O ",
202 " P Q R S T U V W X ", 202 " P Q R S T U V W X ",
203 " Y Z ` b ...+. ", 203 " Y Z ` b ...+. ",
204 " @.#.$.%.&. ", 204 " @.#.$.%.&. ",
205 " *.B =. ", 205 " *.B =. ",
206 " n n n n n n n n n "}; 206 " n n n n n n n n n "};
207 207
208 208
209VMemo::VMemo( QWidget *parent, const char *_name ) 209VMemo::VMemo( QWidget *parent, const char *_name )
210 : QWidget( parent, _name ) { 210 : QWidget( parent, _name ) {
211 setFixedHeight( 18 ); 211 setFixedHeight( 18 );
212 setFixedWidth( 14 ); 212 setFixedWidth( 14 );
213 213
214 recording = FALSE; 214 recording = FALSE;
215 215
216 t_timer = new QTimer( this ); 216 t_timer = new QTimer( this );
217 connect( t_timer, SIGNAL( timeout() ), SLOT( timerBreak() ) ); 217 connect( t_timer, SIGNAL( timeout() ), SLOT( timerBreak() ) );
218 218
219 struct utsname name; /* check for embedix kernel running on the zaurus*/ 219 struct utsname name; /* check for embedix kernel running on the zaurus*/
220 if (uname(&name) != -1) { 220 if (uname(&name) != -1) {
221 QString release=name.release; 221 QString release=name.release;
222 222
223 Config vmCfg("Vmemo"); 223 Config vmCfg("Vmemo");
224 vmCfg.setGroup("Defaults"); 224 vmCfg.setGroup("Defaults");
225 int toggleKey = setToggleButton(vmCfg.readNumEntry("toggleKey", -1)); 225 int toggleKey = setToggleButton(vmCfg.readNumEntry("toggleKey", -1));
226 useADPCM = vmCfg.readBoolEntry("use_ADPCM", 0); 226 useADPCM = vmCfg.readBoolEntry("use_ADPCM", 0);
227 227
228 qDebug("toggleKey %d", toggleKey); 228 qDebug("toggleKey %d", toggleKey);
229 229
230 if(release.find("embedix",0,TRUE) !=-1) 230 if(release.find("embedix",0,TRUE) !=-1)
231 systemZaurus=TRUE; 231 systemZaurus=TRUE;
232 else 232 else
233 systemZaurus=FALSE; 233 systemZaurus=FALSE;
234 234
235 myChannel = new QCopChannel( "QPE/VMemo", this ); 235 myChannel = new QCopChannel( "QPE/VMemo", this );
236 connect( myChannel, SIGNAL(received(const QCString&, const QByteArray&)), 236 connect( myChannel, SIGNAL(received(const QCString&, const QByteArray&)),
237 this, SLOT(receive(const QCString&, const QByteArray&)) ); 237 this, SLOT(receive(const QCString&, const QByteArray&)) );
238 238
239 if( toggleKey != -1 ) { 239 if( toggleKey != -1 ) {
240 // QPEApplication::grabKeyboard(); 240 // QPEApplication::grabKeyboard();
241 QCopEnvelope e("QPE/Desktop", "keyRegister(int key, QString channel, QString message)"); 241 QCopEnvelope e("QPE/Desktop", "keyRegister(int key, QString channel, QString message)");
242 // e << 4096; // Key_Escape 242 // e << 4096; // Key_Escape
243 // e << Key_F5; //4148 243 // e << Key_F5; //4148
244 e << toggleKey; 244 e << toggleKey;
245 e << QString("QPE/VMemo"); 245 e << QString("QPE/VMemo");
246 e << QString("toggleRecord()"); 246 e << QString("toggleRecord()");
247 } 247 }
248 if(toggleKey == 1) 248 if(toggleKey == 1)
249 usingIcon=TRUE; 249 usingIcon=TRUE;
250 else 250 else
251 usingIcon=FALSE; 251 usingIcon=FALSE;
252 if( vmCfg.readNumEntry("hideIcon",0) == 1) 252 if( vmCfg.readNumEntry("hideIcon",0) == 1)
253 hide(); 253 hide();
254 } 254 }
255} 255}
256 256
257VMemo::~VMemo() { 257VMemo::~VMemo() {
258} 258}
259 259
260void VMemo::receive( const QCString &msg, const QByteArray &data ) { 260void VMemo::receive( const QCString &msg, const QByteArray &data ) {
261 qDebug("receive"); 261 qDebug("receive");
262 QDataStream stream( data, IO_ReadOnly ); 262 QDataStream stream( data, IO_ReadOnly );
263 263
264 if (msg == "toggleRecord()") { 264 if (msg == "toggleRecord()") {
265 265
266 if (recording) { 266 if (recording) {
267 fromToggle = TRUE; 267 fromToggle = TRUE;
268 mouseReleaseEvent(NULL); 268 mouseReleaseEvent(NULL);
269 stopRecording(); 269 stopRecording();
270 } else { 270 } else {
271 fromToggle = TRUE; 271 fromToggle = TRUE;
272 // mousePressEvent(NULL); 272 // mousePressEvent(NULL);
273 startRecording(); 273 startRecording();
274 } 274 }
275 } 275 }
276} 276}
277 277
278void VMemo::paintEvent( QPaintEvent* ) { 278void VMemo::paintEvent( QPaintEvent* ) {
279 QPainter p(this); 279 QPainter p(this);
280 p.drawPixmap( 0, 1,( const char** ) vmemo_xpm ); 280 p.drawPixmap( 0, 1,( const char** ) vmemo_xpm );
281} 281}
282 282
283void VMemo::mousePressEvent( QMouseEvent * me) { 283void VMemo::mousePressEvent( QMouseEvent * me) {
284 // just to be safe 284 // just to be safe
285 if (recording) { 285 if (recording) {
286 recording = FALSE; 286 recording = FALSE;
287 return; 287 return;
288 } 288 }
289 /* No mousePress/mouseRelease recording on the iPAQ. The REC button on the iPAQ calls these functions 289 /* No mousePress/mouseRelease recording on the iPAQ. The REC button on the iPAQ calls these functions
290 mousePressEvent and mouseReleaseEvent with a NULL parameter. */ 290 mousePressEvent and mouseReleaseEvent with a NULL parameter. */
291 if ( me->button() != LeftButton || me != NULL) 291 if ( me->button() != LeftButton || me != NULL)
292 // if (!systemZaurus && me != NULL) 292 // if (!systemZaurus && me != NULL)
293 return; 293 return;
294 294
295 if(!recording) 295 if(!recording)
296 startRecording(); 296 startRecording();
297 else 297 else
298 stopRecording(); 298 stopRecording();
299} 299}
300 300
301void VMemo::mouseReleaseEvent( QMouseEvent * ) { 301void VMemo::mouseReleaseEvent( QMouseEvent * ) {
302// if(usingIcon && !recording) 302// if(usingIcon && !recording)
303// stopRecording(); 303// stopRecording();
304} 304}
305 305
306bool VMemo::startRecording() { 306bool VMemo::startRecording() {
307 307
308 if ( recording) 308 if ( recording)
309 return FALSE; 309 return FALSE;
310 310
311 Config config( "Vmemo" ); 311 Config config( "Vmemo" );
312 config.setGroup( "System" ); 312 config.setGroup( "System" );
313 313
314 useAlerts = config.readBoolEntry("Alert",1); 314 useAlerts = config.readBoolEntry("Alert",1);
315 if(useAlerts) { 315 if(useAlerts) {
316 316
317 msgLabel = new QLabel( 0, "alertLabel" ); 317 msgLabel = new QLabel( 0, "alertLabel" );
318 msgLabel->setText("<B><P><font size=+2>VMemo-Recording</font></B>"); 318 msgLabel->setText("<B><P><font size=+2>VMemo-Recording</font></B>");
319 msgLabel->show(); 319 msgLabel->show();
320 } 320 }
321 321
322 // if(useAlerts) 322 // if(useAlerts)
323 // QMessageBox::message("VMemo","Really Record?");//) ==1) 323 // QMessageBox::message("VMemo","Really Record?");//) ==1)
324 // return; 324 // return;
325 // } else { 325 // } else {
326 // if (!systemZaurus ) 326 // if (!systemZaurus )
327 // QSound::play(Resource::findSound("vmemob")); 327 // QSound::play(Resource::findSound("vmemob"));
328 // } 328 // }
329 qDebug("Start recording engines"); 329 qDebug("Start recording engines");
330 recording = TRUE; 330 recording = TRUE;
331 331
332 if (openDSP() == -1) { 332 if (openDSP() == -1) {
333 // QMessageBox::critical(0, "vmemo", "Could not open dsp device.\n"+errorMsg, "Abort"); 333 // QMessageBox::critical(0, "vmemo", "Could not open dsp device.\n"+errorMsg, "Abort");
334 // delete msgLabel; 334 // delete msgLabel;
335 recording = FALSE; 335 recording = FALSE;
336 msgLabel=0; 336 msgLabel=0;
337 delete msgLabel; 337 delete msgLabel;
338 338
339 return FALSE; 339 return FALSE;
340 } 340 }
341 341
342 config.setGroup("Defaults"); 342 config.setGroup("Defaults");
343 343
344 QDateTime dt = QDateTime::currentDateTime(); 344 QDateTime dt = QDateTime::currentDateTime();
345 345
346 QString fName; 346 QString fName;
347 config.setGroup( "System" ); 347 config.setGroup( "System" );
348 fName = QPEApplication::documentDir() ; 348 fName = QPEApplication::documentDir() ;
349 fileName = config.readEntry("RecLocation", fName); 349 fileName = config.readEntry("RecLocation", fName);
350 350
351 int s; 351 int s;
352 s=fileName.find(':'); 352 s=fileName.find(':');
353 if(s) 353 if(s)
354 fileName=fileName.right(fileName.length()-s-2); 354 fileName=fileName.right(fileName.length()-s-2);
355 qDebug("pathname will be "+fileName); 355 qDebug("pathname will be "+fileName);
356 356
357 if( fileName.left(1).find('/') == -1) 357 if( fileName.left(1).find('/') == -1)
358 fileName="/"+fileName; 358 fileName="/"+fileName;
359 if( fileName.right(1).find('/') == -1) 359 if( fileName.right(1).find('/') == -1)
360 fileName+="/"; 360 fileName+="/";
361 fName = "vm_"+ dt.toString()+ ".wav"; 361 fName = "vm_"+ dt.toString()+ ".wav";
362 362
363 fileName+=fName; 363 fileName+=fName;
364 // No spaces in the filename 364 // No spaces in the filename
365 fileName.replace(QRegExp("'"),""); 365 fileName.replace(QRegExp("'"),"");
366 fileName.replace(QRegExp(" "),"_"); 366 fileName.replace(QRegExp(" "),"_");
367 fileName.replace(QRegExp(":"),"."); 367 fileName.replace(QRegExp(":"),".");
368 fileName.replace(QRegExp(","),""); 368 fileName.replace(QRegExp(","),"");
369 fileName += ".wav";
369 370
370 qDebug("filename is "+fileName); 371 qDebug("filename is "+fileName);
371// open tmp file here 372// open tmp file here
372 char *pointer; 373 char *pointer;
373 pointer=tmpnam(NULL); 374 pointer=tmpnam(NULL);
374 qDebug("Opening tmp file %s",pointer); 375 qDebug("Opening tmp file %s",pointer);
375 376
376 if(openWAV(pointer ) == -1) { 377 if(openWAV(pointer ) == -1) {
377 378
378// if(openWAV(fileName.latin1()) == -1) { 379// if(openWAV(fileName.latin1()) == -1) {
379 QString err("Could not open the temp file\n"); 380 QString err("Could not open the temp file\n");
380 err += fileName; 381 err += fileName;
381 QMessageBox::critical(0, "vmemo", err, "Abort"); 382 QMessageBox::critical(0, "vmemo", err, "Abort");
382 ::close(dsp); 383 ::close(dsp);
383 return FALSE; 384 return FALSE;
384 } 385 }
385 if( record() ) { 386 if( record() ) {
386 387
387 QString cmd; 388 QString cmd;
388 cmd.sprintf("mv %s "+fileName, pointer); 389 cmd.sprintf("mv %s "+fileName, pointer);
389// move tmp file to regular file here 390// move tmp file to regular file here
390 system(cmd.latin1()); 391 system(cmd.latin1());
391 392
392 QArray<int> cats(1); 393 QArray<int> cats(1);
393 cats[0] = config.readNumEntry("Category", 0); 394 cats[0] = config.readNumEntry("Category", 0);
394 395
395 QString dlName("vm_"); 396 QString dlName("vm_");
396 dlName += dt.toString(); 397 dlName += dt.toString();
397 DocLnk l; 398 DocLnk l;
398 l.setFile(fileName); 399 l.setFile(fileName);
399 l.setName(dlName); 400 l.setName(dlName);
400 l.setType("audio/x-wav"); 401 l.setType("audio/x-wav");
401 l.setCategories(cats); 402 l.setCategories(cats);
402 l.writeLink(); 403 l.writeLink();
403 return TRUE; 404 return TRUE;
404 } else 405 } else
405 return FALSE; 406 return FALSE;
406 407
407} 408}
408 409
409void VMemo::stopRecording() { 410void VMemo::stopRecording() {
410 show(); 411 show();
411 qDebug("Stopped recording"); 412 qDebug("Stopped recording");
412 recording = FALSE; 413 recording = FALSE;
413 if(useAlerts) { 414 if(useAlerts) {
414 msgLabel->close(); 415 msgLabel->close();
415 msgLabel=0; 416 msgLabel=0;
416 delete msgLabel; 417 delete msgLabel;
417 } 418 }
418 t_timer->stop(); 419 t_timer->stop();
419 Config cfg("Vmemo"); 420 Config cfg("Vmemo");
420 cfg.setGroup("Defaults"); 421 cfg.setGroup("Defaults");
421 if( cfg.readNumEntry("hideIcon",0) == 1 ) 422 if( cfg.readNumEntry("hideIcon",0) == 1 )
422 hide(); 423 hide();
423} 424}
424 425
425int VMemo::openDSP() { 426int VMemo::openDSP() {
426 Config cfg("Vmemo"); 427 Config cfg("Vmemo");
427 cfg.setGroup("Record"); 428 cfg.setGroup("Record");
428 429
429 speed = cfg.readNumEntry("SampleRate", 22050); 430 speed = cfg.readNumEntry("SampleRate", 22050);
430 channels = cfg.readNumEntry("Stereo", 1) ? 2 : 1; // 1 = stereo(2), 0 = mono(1) 431 channels = cfg.readNumEntry("Stereo", 1) ? 2 : 1; // 1 = stereo(2), 0 = mono(1)
431 if (cfg.readNumEntry("SixteenBit", 1)==1) { 432 if (cfg.readNumEntry("SixteenBit", 1)==1) {
432 format = AFMT_S16_LE; 433 format = AFMT_S16_LE;
433 resolution = 16; 434 resolution = 16;
434 } else { 435 } else {
435 format = AFMT_U8; 436 format = AFMT_U8;
436 resolution = 8; 437 resolution = 8;
437 } 438 }
438 439
439 qDebug("samplerate: %d, channels %d, resolution %d", speed, channels, resolution); 440 qDebug("samplerate: %d, channels %d, resolution %d", speed, channels, resolution);
440 441
441 if(systemZaurus) { 442 if(systemZaurus) {
442 dsp = open("/dev/dsp1", O_RDONLY); //Zaurus needs /dev/dsp1 443 dsp = open("/dev/dsp1", O_RDONLY); //Zaurus needs /dev/dsp1
443 channels=1; //zaurus has one input channel 444 channels=1; //zaurus has one input channel
444 } else { 445 } else {
445 dsp = open("/dev/dsp", O_RDONLY); 446 dsp = open("/dev/dsp", O_RDONLY);
446 } 447 }
447 448
448 if(dsp == -1) { 449 if(dsp == -1) {
449 perror("open(\"/dev/dsp\")"); 450 perror("open(\"/dev/dsp\")");
450 errorMsg="open(\"/dev/dsp\")\n "+(QString)strerror(errno); 451 errorMsg="open(\"/dev/dsp\")\n "+(QString)strerror(errno);
451 QMessageBox::critical(0, "vmemo", errorMsg, "Abort"); 452 QMessageBox::critical(0, "vmemo", errorMsg, "Abort");
452 return -1; 453 return -1;
453 } 454 }
454 455
455 if(ioctl(dsp, SNDCTL_DSP_SETFMT , &format)==-1) { 456 if(ioctl(dsp, SNDCTL_DSP_SETFMT , &format)==-1) {
456 perror("ioctl(\"SNDCTL_DSP_SETFMT\")"); 457 perror("ioctl(\"SNDCTL_DSP_SETFMT\")");
457 return -1; 458 return -1;
458 } 459 }
459 if(ioctl(dsp, SNDCTL_DSP_CHANNELS , &channels)==-1) { 460 if(ioctl(dsp, SNDCTL_DSP_CHANNELS , &channels)==-1) {
460 perror("ioctl(\"SNDCTL_DSP_CHANNELS\")"); 461 perror("ioctl(\"SNDCTL_DSP_CHANNELS\")");
461 return -1; 462 return -1;
462 } 463 }
463 if(ioctl(dsp, SNDCTL_DSP_SPEED , &speed)==-1) { 464 if(ioctl(dsp, SNDCTL_DSP_SPEED , &speed)==-1) {
464 perror("ioctl(\"SNDCTL_DSP_SPEED\")"); 465 perror("ioctl(\"SNDCTL_DSP_SPEED\")");
465 return -1; 466 return -1;
466 } 467 }
467 if(ioctl(dsp, SOUND_PCM_READ_RATE , &rate)==-1) { 468 if(ioctl(dsp, SOUND_PCM_READ_RATE , &rate)==-1) {
468 perror("ioctl(\"SOUND_PCM_READ_RATE\")"); 469 perror("ioctl(\"SOUND_PCM_READ_RATE\")");
469 return -1; 470 return -1;
470 } 471 }
471 472
472 QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << FALSE; //mute 473 QCopEnvelope( "QPE/System", "volumeChange(bool)" ) << FALSE; //mute
473 474
474 return 1; 475 return 1;
475} 476}
476 477
477int VMemo::openWAV(const char *filename) { 478int VMemo::openWAV(const char *filename) {
478 track.setName(filename); 479 track.setName(filename);
479 if(!track.open(IO_WriteOnly|IO_Truncate|IO_Raw)) { 480 if(!track.open(IO_WriteOnly|IO_Truncate|IO_Raw)) {
480 errorMsg=filename; 481 errorMsg=filename;
481 return -1; 482 return -1;
482 } 483 }
483 484
484 wav=track.handle(); 485 wav=track.handle();
485 useADPCM = vmCfg.readBoolEntry("use_ADPCM", 0); 486 useADPCM = vmCfg.readBoolEntry("use_ADPCM", 0);
486 487
487 WaveHeader wh; 488 WaveHeader wh;
488 489
489 wh.main_chunk = RIFF; 490 wh.main_chunk = RIFF;
490 wh.length=0; 491 wh.length=0;
491 wh.chunk_type = WAVE; 492 wh.chunk_type = WAVE;
492 wh.sub_chunk = FMT; 493 wh.sub_chunk = FMT;
493 wh.sc_len = 16; 494 wh.sc_len = 16;
494 if(useADPCM) 495 if(useADPCM)
495 wh.format = WAVE_FORMAT_DVI_ADPCM;//PCM_CODE; 496 wh.format = WAVE_FORMAT_DVI_ADPCM;//PCM_CODE;
496 else 497 else
497 wh.format = PCM_CODE; 498 wh.format = PCM_CODE;
498 wh.modus = channels; 499 wh.modus = channels;
499 wh.sample_fq = speed; 500 wh.sample_fq = speed;
500 wh.byte_p_sec = speed * channels * resolution/8; 501 wh.byte_p_sec = speed * channels * resolution/8;
501 wh.byte_p_spl = channels * (resolution / 8); 502 wh.byte_p_spl = channels * (resolution / 8);
502 wh.bit_p_spl = resolution; 503 wh.bit_p_spl = resolution;
503 wh.data_chunk = DATA; 504 wh.data_chunk = DATA;
504 wh.data_length= 0; 505 wh.data_length= 0;
505 // qDebug("Write header channels %d, speed %d, b/s %d, blockalign %d, bitrate %d" 506 // qDebug("Write header channels %d, speed %d, b/s %d, blockalign %d, bitrate %d"
506 // , wh.modus, wh.sample_fq, wh.byte_p_sec, wh.byte_p_spl, wh.bit_p_spl ); 507 // , wh.modus, wh.sample_fq, wh.byte_p_sec, wh.byte_p_spl, wh.bit_p_spl );
507 write (wav, &wh, sizeof(WaveHeader)); 508 write (wav, &wh, sizeof(WaveHeader));
508 509
509 return 1; 510 return 1;
510} 511}
511 512
512bool VMemo::record() { 513bool VMemo::record() {
513 514
514 int length=0, result, value; 515 int length=0, result, value;
515 QString msg; 516 QString msg;
516 msg.sprintf("Recording format %d", format); 517 msg.sprintf("Recording format %d", format);
517 qDebug(msg); 518 qDebug(msg);
518 Config config("Vmemo"); 519 Config config("Vmemo");
519 config.setGroup("Record"); 520 config.setGroup("Record");
520 int sRate=config.readNumEntry("SizeLimit", 30); 521 int sRate=config.readNumEntry("SizeLimit", 30);
521 if(sRate > 0) 522 if(sRate > 0)
522 t_timer->start( sRate * 1000+1000, TRUE); 523 t_timer->start( sRate * 1000+1000, TRUE);
523 524
524// if(systemZaurus) { 525// if(systemZaurus) {
525// } else { // 16 bit only capabilities 526// } else { // 16 bit only capabilities
526 527
527 msg.sprintf("Recording format other"); 528 msg.sprintf("Recording format other");
528 qDebug(msg); 529 qDebug(msg);
529 530
530 int bufsize=1024; 531 int bufsize=1024;
531 int bytesWritten=0; 532 int bytesWritten=0;
532 signed short sound[1024], monoBuffer[1024]; 533 signed short sound[1024], monoBuffer[1024];
533 char abuf[bufsize/2]; 534 char abuf[bufsize/2];
534 short sbuf[bufsize]; 535 short sbuf[bufsize];
535 useADPCM = vmCfg.readBoolEntry("use_ADPCM", 0); 536 useADPCM = vmCfg.readBoolEntry("use_ADPCM", 0);
536 537
537 while(recording) { 538 while(recording) {
538 539
539 if(useADPCM) 540 if(useADPCM)
540 result = read( dsp, sbuf, bufsize); // 8192 541 result = read( dsp, sbuf, bufsize); // 8192
541 else 542 else
542 result = read(dsp, sound, 1024); // 8192 543 result = read(dsp, sound, 1024); // 8192
543 if( result <= 0) { 544 if( result <= 0) {
544 perror("recording error "); 545 perror("recording error ");
545// qDebug(currentFileName); 546// qDebug(currentFileName);
546 QMessageBox::message(tr("Note"),tr("error recording")); 547 QMessageBox::message(tr("Note"),tr("error recording"));
547 recording=FALSE; 548 recording=FALSE;
548 break; 549 break;
549 return FALSE; 550 return FALSE;
550 } 551 }
551 552
552 if(useADPCM) { 553 if(useADPCM) {
553 adpcm_coder( sbuf, abuf, result/2, &encoder_state); 554 adpcm_coder( sbuf, abuf, result/2, &encoder_state);
554 bytesWritten = ::write(wav, abuf, result/4); 555 bytesWritten = ::write(wav, abuf, result/4);
555 556
556 } else { 557 } else {
557 for (int i = 0; i < result; i++) { //since Z is mono do normally 558 for (int i = 0; i < result; i++) { //since Z is mono do normally
558 monoBuffer[i] = sound[i]; 559 monoBuffer[i] = sound[i];
559 } 560 }
560 561