From: Andreas Monzner Date: Sat, 13 Jan 2007 01:01:08 +0000 (+0000) Subject: fix remove last entry in list X-Git-Tag: 2.6.0~2452 X-Git-Url: https://git.cweiske.de/enigma2.git/commitdiff_plain/1f497d5b863644889bda758eed836a3d6be7be11?hp=28d2a74b9141e0b8bafbe4f708181dba0fe66ea6 fix remove last entry in list --- diff --git a/lib/service/listboxservice.cpp b/lib/service/listboxservice.cpp index d87e3155..8bb02611 100644 --- a/lib/service/listboxservice.cpp +++ b/lib/service/listboxservice.cpp @@ -11,25 +11,40 @@ void eListboxServiceContent::addService(const eServiceReference &service, bool b m_list.insert(m_cursor, service); else m_list.push_back(service); - ++m_size; - ++m_cursor_number; - if (m_listbox) - m_listbox->entryAdded(m_cursor_number-1); + if (m_size++) + { + ++m_cursor_number; + if (m_listbox) + m_listbox->entryAdded(m_cursor_number-1); + } + else + { + m_cursor = m_list.begin(); + m_cursor_number=0; + m_listbox->entryAdded(0); + } } void eListboxServiceContent::removeCurrent() { if (m_size && m_listbox) { - --m_size; - if (m_cursor_number == m_size-1) + if (m_cursor_number == --m_size) { m_list.erase(m_cursor--); - --m_cursor_number; + if (m_size) + { + --m_cursor_number; + m_listbox->entryRemoved(m_cursor_number+1); + } + else + m_listbox->entryRemoved(m_cursor_number); } else + { m_list.erase(m_cursor++); - m_listbox->entryRemoved(m_cursor_number+1); + m_listbox->entryRemoved(m_cursor_number); + } } }