diff options
| author | Andreas Monzner <andreas.monzner@multimedia-labs.de> | 2007-11-14 14:56:16 +0000 |
|---|---|---|
| committer | Andreas Monzner <andreas.monzner@multimedia-labs.de> | 2007-11-14 14:56:16 +0000 |
| commit | d4969fafffd49c4791f56141d57281a83007a29b (patch) | |
| tree | 20c7ed14b05fce6b63a484ac9a796289a7adbcba /lib/base/ebase.cpp | |
| parent | 466d0d3e9f5f6b6fc409a73ad26f9b0483d12f32 (diff) | |
| download | enigma2-d4969fafffd49c4791f56141d57281a83007a29b.tar.gz enigma2-d4969fafffd49c4791f56141d57281a83007a29b.zip | |
fix frequently segfault on clean shutdown
Diffstat (limited to 'lib/base/ebase.cpp')
| -rw-r--r-- | lib/base/ebase.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/lib/base/ebase.cpp b/lib/base/ebase.cpp index 08c15610..effd7250 100644 --- a/lib/base/ebase.cpp +++ b/lib/base/ebase.cpp @@ -116,6 +116,16 @@ void eTimer::addTimeOffset( int offset ) // mainloop ePtrList<eMainloop> eMainloop::existing_loops; +eMainloop::~eMainloop() +{ + existing_loops.remove(this); + pthread_mutex_destroy(&recalcLock); + for (std::map<int, eSocketNotifier*>::iterator it(notifiers.begin());it != notifiers.end();++it) + it->second->stop(); + while(m_timer_list.begin() != m_timer_list.end()) + m_timer_list.begin()->stop(); +} + void eMainloop::addSocketNotifier(eSocketNotifier *sn) { int fd = sn->getFD(); |
