diff options
| author | Andreas Monzner <andreas.monzner@multimedia-labs.de> | 2006-11-06 23:18:59 +0000 |
|---|---|---|
| committer | Andreas Monzner <andreas.monzner@multimedia-labs.de> | 2006-11-06 23:18:59 +0000 |
| commit | 9f51417be9d86ef8f21116d2ecd15e536f67783c (patch) | |
| tree | 34e484b3c2bc556a1164c3e732346a2ac98d58c4 /lib/dvb/scan.cpp | |
| parent | 6ebe2f45ec609f3769a4a57e4bbbf776aa3cb930 (diff) | |
| download | enigma2-9f51417be9d86ef8f21116d2ecd15e536f67783c.tar.gz enigma2-9f51417be9d86ef8f21116d2ecd15e536f67783c.zip | |
fix cable brute force scan
Diffstat (limited to 'lib/dvb/scan.cpp')
| -rw-r--r-- | lib/dvb/scan.cpp | 39 |
1 files changed, 33 insertions, 6 deletions
diff --git a/lib/dvb/scan.cpp b/lib/dvb/scan.cpp index f49607c2..70c3e6b3 100644 --- a/lib/dvb/scan.cpp +++ b/lib/dvb/scan.cpp @@ -283,14 +283,27 @@ void eDVBScan::addChannelToScan(const eDVBChannelID &chid, iDVBFrontendParameter } } + int found_count=0; /* ... in the list of channels to scan */ - for (std::list<ePtr<iDVBFrontendParameters> >::iterator i(m_ch_toScan.begin()); i != m_ch_toScan.end(); ++i) + for (std::list<ePtr<iDVBFrontendParameters> >::iterator i(m_ch_toScan.begin()); i != m_ch_toScan.end();) + { if (sameChannel(*i, feparm)) { - *i = feparm; // update - eDebug("update"); - return; + if (!found_count) + { + *i = feparm; // update + eDebug("update"); + } + else + { + eDebug("remove dupe"); + m_ch_toScan.erase(i++); + continue; + } + ++found_count; } + ++i; + } /* ... in the list of successfully scanned channels */ for (std::list<ePtr<iDVBFrontendParameters> >::const_iterator i(m_ch_scanned.begin()); i != m_ch_scanned.end(); ++i) @@ -489,9 +502,23 @@ void eDVBScan::channelDone() if (!m_chid_current) eWarning("SCAN: the current channel's ID was not corrected - not adding channel."); else + { addKnownGoodChannel(m_chid_current, m_ch_current); - m_ch_scanned.push_back(m_ch_current); + m_ch_scanned.push_back(m_ch_current); + + for (std::list<ePtr<iDVBFrontendParameters> >::iterator i(m_ch_toScan.begin()); i != m_ch_toScan.end();) + { + if (sameChannel(*i, m_ch_current)) + { + eDebug("remove dupe 2"); + m_ch_toScan.erase(i++); + continue; + } + ++i; + } + } + nextChannel(); } @@ -510,7 +537,7 @@ void eDVBScan::start(const eSmartPtrList<iDVBFrontendParameters> &known_transpon bool exist=false; for (std::list<ePtr<iDVBFrontendParameters> >::const_iterator ii(m_ch_toScan.begin()); ii != m_ch_toScan.end(); ++ii) { - if (sameChannel(*i, *ii)) + if (sameChannel(*i, *ii, true)) { exist=true; break; |
