- fixed console input mode restore
[enigma2.git] / lib / components / scan.cpp
diff --git a/lib/components/scan.cpp b/lib/components/scan.cpp
new file mode 100644 (file)
index 0000000..4d8d8b7
--- /dev/null
@@ -0,0 +1,109 @@
+#include <lib/dvb/dvb.h>
+#include <lib/dvb/db.h>
+#include <lib/components/scan.h>
+#include <lib/base/eerror.h>
+#include <lib/dvb/scan.h>
+
+DEFINE_REF(eComponentScan);
+
+void eComponentScan::scanEvent(int evt)
+{
+       eDebug("scan event %d!", evt);
+       
+       if (evt == eDVBScan::evtFinish)
+       {
+               m_done = 1;
+               ePtr<iDVBChannelList> db;
+               ePtr<eDVBResourceManager> res;
+               
+               int err;
+               if ((err = eDVBResourceManager::getInstance(res)) != 0)
+               {
+                       eDebug("no resource manager");
+                       return;
+               }
+               if ((err = res->getChannelList(db)) != 0)
+               {
+                       eDebug("no channel list");
+                       return;
+               }
+               
+               m_scan->insertInto(db);
+               
+               eDebug("scan done!");
+       }
+       
+       statusChanged();
+}
+
+eComponentScan::eComponentScan(): m_done(-1)
+{
+}
+
+eComponentScan::~eComponentScan()
+{
+}
+
+int eComponentScan::start()
+{
+       if (m_done != -1)
+               return -1;
+       
+       m_done = 0;
+       ePtr<eDVBResourceManager> mgr;
+       
+       eDVBResourceManager::getInstance(mgr);
+       
+       eDVBFrontendParametersSatellite fesat;
+               
+       fesat.frequency = 11817000; // 12070000;
+       fesat.symbol_rate = 27500000;
+       fesat.polarisation = eDVBFrontendParametersSatellite::Polarisation::Vertical;
+       fesat.fec = eDVBFrontendParametersSatellite::FEC::f3_4;
+       fesat.inversion = eDVBFrontendParametersSatellite::Inversion::Off;
+       fesat.orbital_position = 192;
+
+       eDVBFrontendParameters *fe = new eDVBFrontendParameters();
+       
+       fe->setDVBS(fesat);
+       
+       ePtr<iDVBChannel> channel;
+
+       if (mgr->allocateRawChannel(channel))
+               eDebug("scan: allocating raw channel failed!");
+
+       std::list<ePtr<iDVBFrontendParameters> > list;
+               
+       list.push_back(fe);
+       
+       m_scan = new eDVBScan(channel);
+       m_scan->start(list);
+       m_scan->connectEvent(slot(*this, &eComponentScan::scanEvent), m_scan_event_connection);
+
+       return 0;
+}
+
+int eComponentScan::getProgress()
+{
+       if (!m_scan)
+               return 0;
+       int done, total, services;
+       m_scan->getStats(done, total, services);
+       if (!total)
+               return 0;
+       return done * 100 / total;
+}
+
+int eComponentScan::getNumServices()
+{
+       if (!m_scan)
+               return 0;
+       int done, total, services;
+       m_scan->getStats(done, total, services);
+       return services;
+}
+
+int eComponentScan::isDone()
+{
+       return m_done;
+}