diff options
author | Jim Ramsay <i.am@jimramsay.com> | 2010-07-14 15:36:00 (GMT) |
---|---|---|
committer | Jim Ramsay <i.am@jimramsay.com> | 2010-07-14 15:36:00 (GMT) |
commit | a3b063292c003a32c72859f3eecc92de6e1dd132 (patch) | |
tree | fee8d5fe84771d328e35087a8b183d123895801b | |
parent | 3578d1474180ea151adf20ca745aa4ce3f4b3059 (diff) | |
download | fluxbox_pavel-a3b063292c003a32c72859f3eecc92de6e1dd132.zip fluxbox_pavel-a3b063292c003a32c72859f3eecc92de6e1dd132.tar.bz2 |
bugfix: another crash when cleaning up signals
While 769130f51a8f did fix one issue, it introduced another by changing the
logic related to the new SignalTracker. The original logic (introduced in
9ad388c5bf16) was:
-> in 'leave(Signal)', only call 'disconnect'
-> in 'leaveAll()', call 'disconnect' and 'disconnectTracker'
But 769130f51a8f inverted this, calling 'disconnectTracker' in both cases but
only 'disconnect' in the 'leaveAll()' case, which would leave unattached signals
around after calling 'leave(Signal)'.
This fix not only repairs the logic, but renames the ambiguous 'disconnect'
boolean to something more explicit: 'withTracker'.
-rw-r--r-- | src/FbTk/Signal.hh | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/src/FbTk/Signal.hh b/src/FbTk/Signal.hh index b70c501..3c17d1a 100644 --- a/src/FbTk/Signal.hh +++ b/src/FbTk/Signal.hh | |||
@@ -242,14 +242,14 @@ public: | |||
242 | 242 | ||
243 | /// Leave tracking for a signal | 243 | /// Leave tracking for a signal |
244 | /// @param id the \c id from the previous \c join | 244 | /// @param id the \c id from the previous \c join |
245 | void leave(TrackID id, bool disconnect = false) { | 245 | void leave(TrackID id, bool withTracker = false) { |
246 | // keep temporary, while disconnecting we can | 246 | // keep temporary, while disconnecting we can |
247 | // in some strange cases get a call to this again | 247 | // in some strange cases get a call to this again |
248 | ValueType tmp = *id; | 248 | ValueType tmp = *id; |
249 | m_connections.erase(id); | 249 | m_connections.erase(id); |
250 | if (disconnect) | 250 | tmp.first->disconnect(tmp.second); |
251 | tmp.first->disconnect(tmp.second); | 251 | if (withTracker) |
252 | tmp.first->disconnectTracker(*this); | 252 | tmp.first->disconnectTracker(*this); |
253 | } | 253 | } |
254 | 254 | ||
255 | /// Leave tracking for a signal | 255 | /// Leave tracking for a signal |