]> git.vomp.tv Git - vompclient.git/blob - demuxer.h
PES Packet object: dynamic sizing
[vompclient.git] / demuxer.h
1 /*
2     Copyright 2005-2008 Mark Calderbank
3     Copyright 2007 Marten Richter (AC3 support)
4
5     This file is part of VOMP.
6
7     VOMP is free software; you can redistribute it and/or modify
8     it under the terms of the GNU General Public License as published by
9     the Free Software Foundation; either version 2 of the License, or
10     (at your option) any later version.
11
12     VOMP is distributed in the hope that it will be useful,
13     but WITHOUT ANY WARRANTY; without even the implied warranty of
14     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15     GNU General Public License for more details.
16
17     You should have received a copy of the GNU General Public License
18     along with VOMP; if not, write to the Free Software Foundation, Inc.,
19     51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
20 */
21
22 /*
23
24 Thanks go to Jon Gettler of the MVPMC project and Stephen Rice for
25 the demuxer in mvpmc. It was used in the creation of this demuxer;
26 however, no code was copied verbatim.
27
28 */
29
30 #ifndef DEMUXER_H
31 #define DEMUXER_H
32
33 #include <vector>
34 #include "stream.h"
35 #include "defines.h"
36
37 class Callback;
38 class DrainTarget;
39
40 class PESPacket
41 {
42   public:
43     PESPacket();
44     void init(UCHAR type, UCHAR sub=0);
45     void truncate();
46     int  write(const UCHAR* buf, int len);
47
48     UCHAR operator[] (UINT index) const;
49                        // return data[index] if in bounds, else 0
50                        // so no proper error condition but never mind for now
51     const std::vector<UCHAR>& getData() const { return data; }
52     UINT getLength() const { return length; }
53     UINT getSize() const { return size; }
54     UCHAR getPacketType() const { return packetType; }
55     void setSubstream(UCHAR s) { substream = s; }
56     UCHAR getSubstream() const { return substream; }
57     ULLONG getPTS() const;
58     bool hasPTS() const { return (getPTS() != PTS_INVALID); }
59
60     UINT findPictureHeader() const;
61     UINT findSeqHeader() const;
62     static const ULLONG PTS_INVALID = (1LL << 33);
63   protected:
64     std::vector<UCHAR> data;
65     UINT length, size;
66     UCHAR packetType;
67     UCHAR substream;
68     ULLONG pts;
69     UINT mutable seq_header; // 0 = no, 1 = unknown, else = header offset
70 };
71
72 class Demuxer
73 {
74   public:
75     Demuxer();
76     virtual ~Demuxer();
77     static Demuxer* getInstance();
78     int init(Callback* callback, DrainTarget* audio, DrainTarget* video, ULONG demuxMemoryV, ULONG demuxMemoryA);
79     virtual void reset();
80     virtual void flush();
81     void flushAudio();
82     void seek();
83     void setVideoStream(int id);
84     void setAudioStream(int id);
85     bool writeAudio();
86     bool writeVideo();
87
88     virtual int scan(UCHAR* buf, int len) = 0;
89     virtual int findPTS(UCHAR* buf, int len, ULLONG* dest) = 0;
90     virtual int put(UCHAR* buf, int len) = 0;
91     virtual void setFrameNum(ULONG frame) {}
92     virtual void setPacketNum(ULONG packet) {}
93     virtual ULONG getFrameNumFromPTS(ULLONG pts) {return 0;}
94     virtual ULONG getPacketNum() {return 0;}
95
96     bool* getmpAudioChannels(); //Maybe virtual ?
97     bool* getac3AudioChannels(); //Maybe virtual ?
98     int getselAudioChannel();
99     void setAudioChannel(int aud_channel);
100
101     int getHorizontalSize() { return horizontal_size; }
102     int getVerticalSize() { return vertical_size; }
103     int getAspectRatio() { return aspect_ratio; }
104     int getFrameRate() { return frame_rate; }
105     int getBitRate() { return bit_rate; }
106     ULLONG getVideoPTS() { return video_pts; }
107     ULLONG getAudioPTS() { return audio_pts; }
108
109     enum AspectRatio
110     {
111       ASPECT_4_3  = 2,
112       ASPECT_16_9 = 3
113     };
114
115     // Remove all data from a buffer apart from video PES packets.
116     // Returns the length of the reduced data.
117     // *static function*
118     static UINT stripAudio(UCHAR* buf, UINT len);
119
120     // Scan a buffer to see if video packets are present.
121     // Returns true if video exists; false if not.
122     // *static function*
123     static bool scanForVideo(UCHAR* buf, UINT len);
124
125     enum PESTYPE
126     {
127       PESTYPE_PRIVATE_1 = 0xBD,
128
129       PESTYPE_AUD0 = 0xC0,
130       PESTYPE_AUD1,  PESTYPE_AUD2,  PESTYPE_AUD3,  PESTYPE_AUD4,
131       PESTYPE_AUD5,  PESTYPE_AUD6,  PESTYPE_AUD7,  PESTYPE_AUD8,
132       PESTYPE_AUD9,  PESTYPE_AUD10, PESTYPE_AUD11, PESTYPE_AUD12,
133       PESTYPE_AUD13, PESTYPE_AUD14, PESTYPE_AUD15, PESTYPE_AUD16,
134       PESTYPE_AUD17, PESTYPE_AUD18, PESTYPE_AUD19, PESTYPE_AUD20,
135       PESTYPE_AUD21, PESTYPE_AUD22, PESTYPE_AUD23, PESTYPE_AUD24,
136       PESTYPE_AUD25, PESTYPE_AUD26, PESTYPE_AUD27, PESTYPE_AUD28,
137       PESTYPE_AUD29, PESTYPE_AUD30, PESTYPE_AUD31,
138       PESTYPE_AUDMAX = PESTYPE_AUD31,
139
140       PESTYPE_VID0 = 0xE0,
141       PESTYPE_VID1,  PESTYPE_VID2,  PESTYPE_VID3,  PESTYPE_VID4,
142       PESTYPE_VID5,  PESTYPE_VID6,  PESTYPE_VID7,  PESTYPE_VID8,
143       PESTYPE_VID9,  PESTYPE_VID10, PESTYPE_VID11, PESTYPE_VID12,
144       PESTYPE_VID13, PESTYPE_VID14, PESTYPE_VID15,
145       PESTYPE_VIDMAX = PESTYPE_VID15
146     };
147     enum PESTYPE_SUBSTREAM
148     {
149       PESTYPE_SUBSTREAM_AC30 = 0x80,
150       PESTYPE_SUBSTREAM_AC31,PESTYPE_SUBSTREAM_AC32, PESTYPE_SUBSTREAM_AC33,
151       PESTYPE_SUBSTREAM_AC34,PESTYPE_SUBSTREAM_AC35,PESTYPE_SUBSTREAM_AC36,
152       PESTYPE_SUBSTREAM_AC37,
153       PESTYPE_SUBSTREAM_AC3MAX = PESTYPE_SUBSTREAM_AC37
154     };
155
156   protected:
157     // Operations on PES packets
158     bool submitPacket(PESPacket&);
159     void parsePacketDetails(PESPacket&);
160
161     // General demuxer objects and status indicators
162     static Demuxer* instance;
163     Stream videostream;
164     Stream audiostream;
165     int shutdown();
166     bool initted;
167     bool vid_seeking;
168     bool aud_seeking;
169     int video_current, audio_current;
170
171     // Video stream information
172     void setAspectRatio(enum AspectRatio);
173     Callback* callback;
174
175     int horizontal_size;
176     int vertical_size;
177     enum AspectRatio aspect_ratio;
178     int arcnt;
179     int frame_rate;
180     int bit_rate;
181     ULLONG video_pts;
182     ULLONG video_pts_seek;
183     ULLONG audio_pts;
184
185     // Constants
186     static const int FrameRates[9];
187
188     bool ispre_1_3_19;
189     bool avail_mpaudchan[PESTYPE_AUDMAX-PESTYPE_AUD0+1];
190     bool avail_ac3audchan[PESTYPE_SUBSTREAM_AC3MAX-PESTYPE_SUBSTREAM_AC30+1];
191 };
192
193 #endif