X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/9c3098c8667241d18d2551a9a37ce7fbce396b71..287f7c2cfaf264b079cce1bf789d118ee444180f:/lib/components/file_eraser.cpp?ds=sidebyside diff --git a/lib/components/file_eraser.cpp b/lib/components/file_eraser.cpp index ea68eb44..9f92fa44 100644 --- a/lib/components/file_eraser.cpp +++ b/lib/components/file_eraser.cpp @@ -11,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() @@ -29,6 +29,7 @@ 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() @@ -43,7 +44,7 @@ void eBackgroundFileEraser::thread() runLoop(); - stop_thread_timer.stop(); + stop_thread_timer->stop(); } void eBackgroundFileEraser::erase(const char *filename) @@ -51,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 @@ -75,7 +76,7 @@ void eBackgroundFileEraser::gotMessage(const Message &msg ) eDebug("file %s erased", msg.filename); free((char*)msg.filename); } - stop_thread_timer.start(1000, true); // stop thread in one seconds + stop_thread_timer->start(1000, true); // stop thread in one seconds break; case Message::quit: quit(0);