diff options
| author | Peter Penz <[email protected]> | 2007-03-24 15:00:38 +0000 |
|---|---|---|
| committer | Peter Penz <[email protected]> | 2007-03-24 15:00:38 +0000 |
| commit | 0ac441acbe51a222d9094a5457e564a97bd60478 (patch) | |
| tree | 2ea7c6f7a9afc0f03e658d8ec314203b5806a5b4 /src/statusbarmessagelabel.cpp | |
| parent | 7c1f67d529bc00a60c59562fc3339a28594a1c15 (diff) | |
improve error handling by queueing old messages
svn path=/trunk/KDE/kdebase/apps/; revision=646091
Diffstat (limited to 'src/statusbarmessagelabel.cpp')
| -rw-r--r-- | src/statusbarmessagelabel.cpp | 17 |
1 files changed, 8 insertions, 9 deletions
diff --git a/src/statusbarmessagelabel.cpp b/src/statusbarmessagelabel.cpp index 6b528d802..c870406d3 100644 --- a/src/statusbarmessagelabel.cpp +++ b/src/statusbarmessagelabel.cpp @@ -61,22 +61,21 @@ StatusBarMessageLabel::~StatusBarMessageLabel() void StatusBarMessageLabel::setMessage(const QString& text, DolphinStatusBar::Type type) { + if ((text == m_text) && (type == m_type)) { + return; + } + if (m_type == DolphinStatusBar::Error) { - // If an error is shown currently, other error messages get queued. - // Non-error messages are ignored if there are pending error messages. if (type == DolphinStatusBar::Error) { - m_pendingMessages.append(text); - return; + m_pendingMessages.insert(0, m_text); } - if ((m_state != Default) || !m_pendingMessages.isEmpty()) { + else if ((m_state != Default) || !m_pendingMessages.isEmpty()) { + // a non-error message should not be shown, as there + // are other pending error messages in the queue return; } } - if ((text == m_text) && (type == m_type)) { - return; - } - m_text = text; m_type = type; |
