aboutsummaryrefslogtreecommitdiff
path: root/lib/service
diff options
context:
space:
mode:
authorAndreas Monzner <andreas.monzner@multimedia-labs.de>2005-11-13 18:25:34 +0000
committerAndreas Monzner <andreas.monzner@multimedia-labs.de>2005-11-13 18:25:34 +0000
commita6d3a3d2a552e2846e8da5a03f7651c5c2e7d6b2 (patch)
treee40e204ccace37d2594ee881240294de734c1e80 /lib/service
parentde0f72b065f83042e6933b63487eb8124e643990 (diff)
downloadenigma2-a6d3a3d2a552e2846e8da5a03f7651c5c2e7d6b2.tar.gz
enigma2-a6d3a3d2a552e2846e8da5a03f7651c5c2e7d6b2.zip
move services in bouquets is now possible.. (bouquet save is missing yet)
Diffstat (limited to 'lib/service')
-rw-r--r--lib/service/listboxservice.cpp30
-rw-r--r--lib/service/servicedvb.cpp26
2 files changed, 42 insertions, 14 deletions
diff --git a/lib/service/listboxservice.cpp b/lib/service/listboxservice.cpp
index f413f2e2..19ff6933 100644
--- a/lib/service/listboxservice.cpp
+++ b/lib/service/listboxservice.cpp
@@ -155,7 +155,37 @@ int eListboxServiceContent::setCurrentMarked(bool state)
m_current_marked = state;
if (state != prev && m_listbox)
+ {
m_listbox->entryChanged(m_cursor_number);
+ if (!state)
+ {
+ ePtr<iListableService> lst;
+ if (m_service_center->list(m_root, lst))
+ eDebug("no list available!");
+ else
+ {
+ ePtr<iMutableServiceList> list;
+ if (lst->startEdit(list))
+ eDebug("no editable list");
+ else
+ {
+ eServiceReference ref;
+ getCurrent(ref);
+ if(!ref)
+ eDebug("no valid service selected");
+ else
+ {
+ int pos = cursorGet();
+ eDebugNoNewLine("move %s to %d ", ref.toString().c_str(), pos);
+ if (list->moveService(ref, cursorGet()))
+ eDebug("failed");
+ else
+ eDebug("ok");
+ }
+ }
+ }
+ }
+ }
return 0;
}
diff --git a/lib/service/servicedvb.cpp b/lib/service/servicedvb.cpp
index 94833f44..b1c18a1d 100644
--- a/lib/service/servicedvb.cpp
+++ b/lib/service/servicedvb.cpp
@@ -66,7 +66,7 @@ RESULT eStaticServiceDVBBouquetInformation::getName(const eServiceReference &ref
return err;
}
- const eBouquet *bouquet=0;
+ eBouquet *bouquet=0;
if ((err = db->getBouquet(ref, bouquet)) != 0)
{
eDebug("eStaticServiceDVBBouquetInformation::getName failed.. getBouquet failed!");
@@ -280,10 +280,9 @@ RESULT eDVBServiceList::startEdit(ePtr<iMutableServiceList> &res)
if (eDVBResourceManager::getInstance(resm) || resm->getChannelList(db))
return -1;
- // FIXME!
- if (db->getBouquet(m_parent, (const eBouquet*&)m_bouquet) != 0)
+ if (db->getBouquet(m_parent, m_bouquet) != 0)
return -1;
-
+
res = this;
return 0;
@@ -294,24 +293,23 @@ RESULT eDVBServiceList::startEdit(ePtr<iMutableServiceList> &res)
RESULT eDVBServiceList::addService(eServiceReference &ref)
{
- ASSERT(m_bouquet);
-// return m_bouquet->addService(ref);
- return -1;
+ if (!m_bouquet)
+ return -1;
+ return m_bouquet->addService(ref);
}
RESULT eDVBServiceList::removeService(eServiceReference &ref)
{
- ASSERT(m_bouquet);
-// return m_bouquet->removeService(ref);
- return -1;
+ if (!m_bouquet)
+ return -1;
+ return m_bouquet->removeService(ref);
}
RESULT eDVBServiceList::moveService(eServiceReference &ref, int pos)
{
- ASSERT(m_bouquet);
-
-// return m_bouquet->moveService(ref, pos);
- return -1;
+ if (!m_bouquet)
+ return -1;
+ return m_bouquet->moveService(ref, pos);
}
RESULT eServiceFactoryDVB::play(const eServiceReference &ref, ePtr<iPlayableService> &ptr)