#ifndef __esection_h
#define __esection_h
-#include <lib/dvb/isection.h>
+#include <lib/dvb/idemux.h>
#include <set>
-class eGTable: public virtual iObject, public Object
+class eGTable: public iObject, public Object
{
-DECLARE_REF;
+DECLARE_REF(eGTable);
private:
ePtr<iDVBSectionReader> m_reader;
eDVBTableSpec m_table;
+ unsigned int m_tries;
+
eTimer *m_timeout;
void sectionRead(const __u8 *data);
void timeout();
ePtr<eConnection> m_sectionRead_conn;
protected:
- virtual int createTable(int nr, const __u8 *data, unsigned int max)=0;
+ virtual int createTable(unsigned int nr, const __u8 *data, unsigned int max)=0;
public:
Signal1<void, int> tableReady;
eGTable();
std::vector<Section*> sections;
std::set<int> avail;
protected:
- int createTable(int nr, const __u8 *data, unsigned int max)
+ int createTable(unsigned int nr, const __u8 *data, unsigned int max)
{
+ unsigned int ssize = sections.size();
+ if (max < ssize || nr >= max)
+ {
+ eDebug("kaputt max(%d) < ssize(%d) || nr(%d) >= max(%d)",
+ max, ssize, nr, max);
+ return 0;
+ }
if (avail.find(nr) != avail.end())
delete sections[nr];
+
sections.resize(max);
-
-
sections[nr] = new Section(data);
avail.insert(nr);
for (unsigned int i = 0; i < max; ++i)
if (avail.find(i) != avail.end())
- printf("+");
+ eDebugNoNewLine("+");
else
- printf("-");
+ eDebugNoNewLine("-");
- printf(" %d/%d\n", avail.size(), max);
+ eDebug(" %d/%d TID %02x", avail.size(), max, data[0]);
if (avail.size() == max)
+ {
+ eDebug("done!");
return 1;
- else
+ } else
return 0;
}
public:
}
~eTable()
{
- for (typename std::vector<Section*>::iterator i(sections.begin()); i != sections.end(); ++i)
- delete *i;
+ for (std::set<int>::iterator i(avail.begin()); i != avail.end(); ++i)
+ delete sections[*i];
}
};
~eAUTable()
{
- current=next=0;
+ stop();
+ }
+
+ void stop()
+ {
+ current = next = 0;
+ m_demux = 0;
}
int begin(eMainloop *m, const eDVBTableSpec &spec, ePtr<iDVBDemux> demux)