X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/2c76959422e7f57e43a359ff1d5ceb74dc4232d5..5f60d706ff61b12a54b4ca0cd94d0cd9cb131404:/lib/components/file_eraser.cpp diff --git a/lib/components/file_eraser.cpp b/lib/components/file_eraser.cpp index 6cacf045..9f92fa44 100644 --- a/lib/components/file_eraser.cpp +++ b/lib/components/file_eraser.cpp @@ -1,4 +1,5 @@ #include +#include #include #include #include @@ -10,12 +11,12 @@ eBackgroundFileEraser *eBackgroundFileEraser::instance; eBackgroundFileEraser::eBackgroundFileEraser() - :messages(this,1), stop_thread_timer(this) + :messages(this,1), stop_thread_timer(eTimer::create(this)) { if (!instance) instance=this; CONNECT(messages.recv_msg, eBackgroundFileEraser::gotMessage); - CONNECT(stop_thread_timer.timeout, eBackgroundFileEraser::idle); + CONNECT(stop_thread_timer->timeout, eBackgroundFileEraser::idle); } void eBackgroundFileEraser::idle() @@ -28,15 +29,22 @@ eBackgroundFileEraser::~eBackgroundFileEraser() messages.send(Message::quit); if (instance==this) instance=0; + kill(); // i dont understand why this is needed .. in ~eThread::eThread is a kill() to.. } void eBackgroundFileEraser::thread() { hasStarted(); + nice(5); + + setIoPrio(IOPRIO_CLASS_BE, 7); + reset(); + runLoop(); - stop_thread_timer.stop(); + + stop_thread_timer->stop(); } void eBackgroundFileEraser::erase(const char *filename) @@ -44,7 +52,7 @@ void eBackgroundFileEraser::erase(const char *filename) if (filename) { char buf[255]; - snprintf(buf, 255, "%s.$$$", filename); + snprintf(buf, 255, "%s.del", filename); if (rename(filename, buf)<0) ;/*perror("rename file failed !!!");*/ else @@ -68,7 +76,7 @@ void eBackgroundFileEraser::gotMessage(const Message &msg ) eDebug("file %s erased", msg.filename); free((char*)msg.filename); } - stop_thread_timer.start(2000, true); // stop thread in two seconds + stop_thread_timer->start(1000, true); // stop thread in one seconds break; case Message::quit: quit(0);