1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
|
#ifndef __lib_dvb_tstools_h
#define __lib_dvb_tstools_h
#include <sys/types.h>
#include <lib/dvb/pvrparse.h>
#include <lib/base/rawfile.h>
/*
* Note: we're interested in PTS values, not STC values.
* thus we're evaluating PES headers, not adaption fields.
*/
typedef long long pts_t;
class eDVBTSTools
{
public:
eDVBTSTools();
~eDVBTSTools();
int openFile(const char *filename, int nostreaminfo = 0);
void closeFile();
void setSyncPID(int pid);
void setSearchRange(int maxrange);
/* get first PTS *after* the given offset. */
/* pts values are zero-based. */
int getPTS(off_t &offset, pts_t &pts, int fixed=0);
/* this fixes up PTS to end up in a [0..len) range.
discontinuities etc. are handled here.
input:
offset - approximate offset in file to resolve ambiguities
pts - video-pts (i.e. current STC of video decoder)
output:
pts - zero-based PTS value
*/
int fixupPTS(const off_t &offset, pts_t &pts);
/* get (approximate) offset corresponding to PTS */
int getOffset(off_t &offset, pts_t &pts);
int getNextAccessPoint(pts_t &ts, const pts_t &start, int direction);
void calcBegin();
void calcEnd();
int calcLen(pts_t &len);
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;
eRawFile m_file;
int m_begin_valid, m_end_valid;
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
|