void eListboxServiceContent::addService(const eServiceReference &service, bool beforeCurrent)
{
if (beforeCurrent && m_size)
- {
m_list.insert(m_cursor, service);
- --m_cursor;
- }
else
m_list.push_back(service);
++m_size;
+ ++m_cursor_number;
+ if (m_listbox)
+ m_listbox->entryAdded(m_cursor_number-1);
}
void eListboxServiceContent::removeCurrent()
{
if (m_size && m_listbox)
{
+ --m_size;
if (m_cursor_number == m_size-1)
{
m_list.erase(m_cursor--);
}
else
m_list.erase(m_cursor++);
- --m_size;
- m_listbox->entryRemoved(m_cursor_number);
+ m_listbox->entryRemoved(m_cursor_number+1);
}
}
ePtr<iStaticServiceInformation> service_info;
m_service_center->info(*m_cursor, service_info);
eServiceReference ref = *m_cursor;
- bool checkPlayable =
- (ref.flags & eServiceReference::flagDirectory) != eServiceReference::flagDirectory ||
- (ref.flags & eServiceReference::isGroup);
+ bool isPlayable = !(ref.flags & eServiceReference::isDirectory || ref.flags & eServiceReference::isMarker);
- if (checkPlayable && m_is_playable_ignore.valid() && service_info && !service_info->isPlayable(*m_cursor, m_is_playable_ignore))
+ if (isPlayable && m_is_playable_ignore.valid() && service_info && !service_info->isPlayable(*m_cursor, m_is_playable_ignore))
painter.setForegroundColor(gRGB(0xbbbbbb));
int xoffset=0; // used as offset when painting the folder/marker symbol
eRect area = m_element_position[p];
int correction = (area.height() - pixmap_size.height()) / 2;
- if (m_cursor->flags & eServiceReference::flagDirectory)
+ if (isPlayable)
+ {
+ if (e != celServiceTypePixmap)
+ continue;
+ m_element_position[celServiceInfo] = area;
+ m_element_position[celServiceInfo].setLeft(area.left() + pixmap_size.width() + 8);
+ m_element_position[celServiceInfo].setWidth(area.width() - pixmap_size.width() - 8);
+ }
+ else if (m_cursor->flags & eServiceReference::isDirectory)
{
if (e != celFolderPixmap)
continue;
continue;
}
else
- {
- if (e != celServiceTypePixmap)
- continue;
- m_element_position[celServiceInfo] = area;
- m_element_position[celServiceInfo].setLeft(area.left() + pixmap_size.width() + 8);
- m_element_position[celServiceInfo].setWidth(area.width() - pixmap_size.width() - 8);
- }
+ eFatal("unknown service type in listboxservice");
area.moveBy(offset);
painter.clip(area);