#ifndef __lib_dvb_scan_h
#define __lib_dvb_scan_h
-#include <dvbsi++/network_information_section.h>
#include <dvbsi++/service_description_section.h>
+#include <dvbsi++/network_information_section.h>
#include <dvbsi++/bouquet_association_section.h>
+#include <dvbsi++/program_association_section.h>
#include <lib/dvb/idemux.h>
#include <lib/dvb/esection.h>
#include <lib/dvb/db.h>
RESULT nextChannel();
RESULT startFilter();
- enum { readySDT=1, readyNIT=2, readyBAT=4,
- validSDT=8, validNIT=16, validBAT=32};
+ enum { readyPAT=1, readySDT=2, readyNIT=4, readyBAT=8,
+ validPAT=16, validSDT=32, validNIT=64, validBAT=128};
/* scan state variables */
int m_channel_state;
ePtr<eTable<ServiceDescriptionSection> > m_SDT;
ePtr<eTable<NetworkInformationSection> > m_NIT;
ePtr<eTable<BouquetAssociationSection> > m_BAT;
-
+ ePtr<eTable<ProgramAssociationSection> > m_PAT;
+
void SDTready(int err);
void NITready(int err);
void BATready(int err);
-
+ void PATready(int err);
+
void addKnownGoodChannel(const eDVBChannelID &chid, iDVBFrontendParameters *feparm);
void addChannelToScan(const eDVBChannelID &chid, iDVBFrontendParameters *feparm);
- int sameChannel(iDVBFrontendParameters *ch1, iDVBFrontendParameters *ch2) const;
-
+
+ int sameChannel(iDVBFrontendParameters *ch1, iDVBFrontendParameters *ch2, bool exact=false) const;
+
void channelDone();
Signal1<void,int> m_event;
RESULT processSDT(eDVBNamespace dvbnamespace, const ServiceDescriptionSection &sdt);
int m_flags;
+ bool m_usePAT;
public:
- eDVBScan(iDVBChannel *channel, bool debug=false);
+ eDVBScan(iDVBChannel *channel, bool usePAT=true, bool debug=true );
~eDVBScan();
- enum { scanNetworkSearch = 1, scanSearchBAT = 2, scanRemoveServices = 4, scanDontRemoveFeeds=8 };
+ enum {
+ scanNetworkSearch = 1, scanSearchBAT = 2,
+ scanRemoveServices = 4, scanDontRemoveFeeds = 8,
+ clearToScanOnFirstNIT = 16 };
+
void start(const eSmartPtrList<iDVBFrontendParameters> &known_transponders, int flags);
enum { evtUpdate, evtNewService, evtFinish, evtFail };