]> git.vomp.tv Git - vompclient.git/blob - draintarget.h
Completion of move recording code. Fixes for dir counts, other bugs.
[vompclient.git] / draintarget.h
1 /*
2     Copyright 2004-2005 Chris Tallon
3
4     This file is part of VOMP.
5
6     VOMP is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     VOMP is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with VOMP; if not, write to the Free Software
18     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19 */
20
21 #ifndef DRAINTARGET_H
22 #define DRAINTARGET_H
23
24 #include "defines.h"
25 #include <list>
26
27
28 #ifdef NEW_DEMUXER
29
30 struct MediaPacket
31 {
32   ULLONG recording_byte_pos; //position in recording
33   ULLONG pts;
34   ULONG pos_buffer; //position in stream buffer
35   ULONG length; //length of the packet
36   //The last to are only needed on windows, for memory reasons they can be excluded in mvp
37   long long presentation_time;/* in 100 ns units*/
38   bool synched;
39   bool disconti;
40 };
41
42 using namespace std;
43
44 typedef list<MediaPacket> MediaPacketList;
45
46 #endif
47
48 class DrainTarget
49 {
50   public:
51     DrainTarget();
52     virtual ~DrainTarget();
53
54 #ifdef NEW_DEMUXER
55
56     virtual UINT DeliverMediaSample(MediaPacket packet, UCHAR* buffer, UINT *samplepos)=0;
57
58     /* This function behaviour should be:
59     Try to deliver the Data from packet.pos_buffer+samplepos to packet.pos_buffer+packet.length,
60     with considering the bufferwraparound according to buffersize.
61     Then increasing samplepos, so that on the next call delivering can proceed. So if writebytes are
62     writen samplepos=samplepos+writebytes!
63     If samplepos>=packet.length is returned, the next packet can be used for the next call.*/
64
65     virtual long long SetStartOffset(long long curreftime, bool *rsync)=0;
66     virtual void ResetTimeOffsets()=0;
67
68 #else
69     virtual int write(UCHAR* buffer, ULONG length)=0;
70 #endif
71
72 };
73
74
75
76
77 #endif
78