eDVBTSTools();
~eDVBTSTools();
- int openFile(const char *filename);
+ int openFile(const char *filename, int nostreaminfo = 0);
void closeFile();
void setSyncPID(int pid);
int fixupPTS(const off_t &offset, pts_t &pts);
/* get (approximate) offset corresponding to PTS */
- int getOffset(off_t &offset, pts_t &pts);
+ int getOffset(off_t &offset, pts_t &pts, int marg=0);
int getNextAccessPoint(pts_t &ts, const pts_t &start, int direction);
int calcBitrate(); /* in bits/sec */
+ void takeSamples();
+ int takeSample(off_t off, pts_t &p);
+
+ int findPMT(int &pmt_pid, int &service_id);
private:
int m_pid;
int m_maxrange;
pts_t m_pts_begin, m_pts_end;
off_t m_offset_begin, m_offset_end;
+ /* for simple linear interpolation */
+ std::map<pts_t, off_t> m_samples;
+ int m_samples_taken;
+
eMPEGStreamInformation m_streaminfo;
int m_use_streaminfo;
+ off_t m_last_filelength;
+ int m_futile;
};
#endif