#include <fcntl.h>
class eDVBCAService;
+class eDVBScan;
typedef std::map<eServiceReferenceDVB, eDVBCAService*> CAServiceMap;
int m_last_channel_state;
eDVBCAService *m_ca_servicePtr;
+ eDVBScan *m_dvb_scan; // for sdt scan
eAUTable<eTable<ProgramMapSection> > m_PMT;
eAUTable<eTable<ProgramAssociationSection> > m_PAT;
ePtr<eConnection> m_channelStateChanged_connection;
void channelEvent(iDVBChannel *, int event);
ePtr<eConnection> m_channelEvent_connection;
+ void SDTScanEvent(int);
+ ePtr<eConnection> m_scan_event_connection;
void PMTready(int error);
void PATready(int error);
+ int m_pmt_pid;
+
int m_use_decode_demux;
uint8_t m_decode_demux_num;
-
public:
eDVBServicePMTHandler();
~eDVBServicePMTHandler();
{
int pid;
int component_tag;
+ enum { vtMPEG2, vtMPEG4_H264 };
+ int type;
};
struct audioStream
{
int pid;
- enum { atMPEG, atAC3, atDTS };
+ enum { atMPEG, atAC3, atDTS, atAAC };
int type; // mpeg2, ac3, dts, ...
int component_tag;
std::string language_code; /* iso-639, if available. */
};
-
+
+ struct subtitleStream
+ {
+ int pid;
+ int subtitling_type; /* see ETSI EN 300 468 table 26 component_type
+ when stream_content is 0x03
+ 0x10..0x13, 0x20..0x23 is used for dvb subtitles
+ 0x01 is used for teletext subtitles */
+ union
+ {
+ int composition_page_id; // used for dvb subtitles
+ int teletext_page_number; // used for teletext subtitles
+ };
+ union
+ {
+ int ancillary_page_id; // used for dvb subtitles
+ int teletext_magazine_number; // used for teletext subtitles
+ };
+ std::string language_code;
+ bool operator<(const subtitleStream &s) const
+ {
+ if (pid != s.pid)
+ return pid < s.pid;
+ if (teletext_page_number != s.teletext_page_number)
+ return teletext_page_number < s.teletext_page_number;
+ return teletext_magazine_number < s.teletext_magazine_number;
+ }
+ };
+
struct program
{
std::vector<videoStream> videoStreams;
std::vector<audioStream> audioStreams;
- // ca info
+ std::vector<subtitleStream> subtitleStreams;
+ std::set<uint16_t> caids;
int pcrPid;
int pmtPid;
int textPid;
- bool isCrypted;
+ bool isCrypted() { return !caids.empty(); }
};
-
+
int getProgramInfo(struct program &program);
int getDataDemux(ePtr<iDVBDemux> &demux);
int getDecodeDemux(ePtr<iDVBDemux> &demux);
PyObject *getCaIds();
int getPVRChannel(ePtr<iDVBPVRChannel> &pvr_channel);
- int getService(eServiceReferenceDVB &service) { service = m_reference; return 0; }
+ int getServiceReference(eServiceReferenceDVB &service) { service = m_reference; return 0; }
+ int getService(ePtr<eDVBService> &service) { service = m_service; return 0; }
int getPMT(ePtr<eTable<ProgramMapSection> > &ptr) { return m_PMT.getCurrent(ptr); }
int getChannel(eUsePtr<iDVBChannel> &channel);
+ void resetCachedProgram() { m_have_cached_program = false; }
int tune(eServiceReferenceDVB &ref, int use_decode_demux, eCueSheet *sg=0);
void free();
-
- int m_pmt_pid;
+private:
+ bool m_have_cached_program;
+ program m_cached_program;
};
#endif