diff options
| author | Andreas Monzner <andreas.monzner@multimedia-labs.de> | 2007-09-14 23:28:08 +0000 |
|---|---|---|
| committer | Andreas Monzner <andreas.monzner@multimedia-labs.de> | 2007-09-14 23:28:08 +0000 |
| commit | 09047544dbeddd0a5df972934c8863bef9e11a99 (patch) | |
| tree | c7cb8f385c76e026cee353190fe1ef40dd09b6ff /lib | |
| parent | 0c583555037c4d937caa03585cb5548282cddf09 (diff) | |
| download | enigma2-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')
| -rw-r--r-- | lib/components/scan.cpp | 41 |
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; } |
