aboutsummaryrefslogtreecommitdiff
path: root/lib/components
diff options
context:
space:
mode:
authorAndreas Monzner <andreas.monzner@multimedia-labs.de>2007-09-14 23:28:08 +0000
committerAndreas Monzner <andreas.monzner@multimedia-labs.de>2007-09-14 23:28:08 +0000
commit09047544dbeddd0a5df972934c8863bef9e11a99 (patch)
treec7cb8f385c76e026cee353190fe1ef40dd09b6ff /lib/components
parent0c583555037c4d937caa03585cb5548282cddf09 (diff)
downloadenigma2-09047544dbeddd0a5df972934c8863bef9e11a99.tar.gz
enigma2-09047544dbeddd0a5df972934c8863bef9e11a99.zip
remove new found flags when do a automatic scan and "clear before scan" was
not checked
Diffstat (limited to 'lib/components')
-rw-r--r--lib/components/scan.cpp41
1 files changed, 39 insertions, 2 deletions
diff --git a/lib/components/scan.cpp b/lib/components/scan.cpp
index 79fe2ef5..a863d923 100644
--- a/lib/components/scan.cpp
+++ b/lib/components/scan.cpp
@@ -106,11 +106,48 @@ int eComponentScan::start(int feid, int flags)
}
std::list<ePtr<iDVBFrontendParameters> > list;
-
m_scan = new eDVBScan(channel);
m_scan->connectEvent(slot(*this, &eComponentScan::scanEvent), m_scan_event_connection);
+
+ if (!(flags & scanRemoveServices))
+ {
+ ePtr<iDVBChannelList> db;
+ ePtr<eDVBResourceManager> res;
+ int err;
+ if ((err = eDVBResourceManager::getInstance(res)) != 0)
+ eDebug("no resource manager");
+ else if ((err = res->getChannelList(db)) != 0)
+ eDebug("no channel list");
+ else
+ {
+ if (m_initial.size() > 1)
+ {
+ iDVBFrontendParameters *tp = m_initial.first();
+ int type;
+ if (tp && !tp->getSystem(type))
+ {
+ switch(type)
+ {
+ case iDVBFrontend::feSatellite:
+ {
+ eDVBFrontendParametersSatellite parm;
+ tp->getDVBS(parm);
+ db->removeFlags(eDVBService::dxNewFound, -1, -1, -1, parm.orbital_position);
+ break;
+ }
+ case iDVBFrontend::feCable:
+ db->removeFlags(eDVBService::dxNewFound, 0xFFFF0000, -1, -1, -1);
+ break;
+ case iDVBFrontend::feTerrestrial:
+ db->removeFlags(eDVBService::dxNewFound, 0xEEEE0000, -1, -1, -1);
+ break;
+ }
+ }
+ }
+ }
+ }
m_scan->start(m_initial, flags);
-
+
return 0;
}