Mercurial > mplayer.hg
annotate libmpdemux/stream.h @ 4314:7fae2ec7c968
FreeBSD need this to compile after last changes
author | nexus |
---|---|
date | Wed, 23 Jan 2002 13:57:43 +0000 |
parents | e889d37f25b2 |
children | 0d5cba15772b |
rev | line source |
---|---|
998
8c83e3ff26cc
Added ifndef to prevent multiple header file inclusion.
bertrand
parents:
692
diff
changeset
|
1 #ifndef __STREAM_H |
8c83e3ff26cc
Added ifndef to prevent multiple header file inclusion.
bertrand
parents:
692
diff
changeset
|
2 #define __STREAM_H |
578 | 3 |
4029
3c87dee7a324
patch for missing include by Steven M. Schultz <sms@2BSD.COM>
pl
parents:
3998
diff
changeset
|
4 #include <inttypes.h> |
3c87dee7a324
patch for missing include by Steven M. Schultz <sms@2BSD.COM>
pl
parents:
3998
diff
changeset
|
5 |
578 | 6 #define STREAM_BUFFER_SIZE 2048 |
7 | |
8 #define STREAMTYPE_FILE 0 | |
9 #define STREAMTYPE_VCD 1 | |
692 | 10 #define STREAMTYPE_STREAM 2 // same as FILE but no seeking (for stdin) |
1594 | 11 #define STREAMTYPE_DVD 3 |
2144 | 12 #define STREAMTYPE_MEMORY 4 |
2790 | 13 #define STREAMTYPE_TV 5 |
4042
d651a7b5d213
STREAMTYPE_PLAYLIST introduced. similar to STREAMTYPE_STREAM but used for playlists. patch by Alban Bedel <albeu@free.fr>
arpi
parents:
4029
diff
changeset
|
14 #define STREAMTYPE_PLAYLIST 6 |
578 | 15 |
16 #define VCD_SECTOR_SIZE 2352 | |
17 #define VCD_SECTOR_OFFS 24 | |
18 #define VCD_SECTOR_DATA 2324 | |
19 | |
3043
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
20 #ifdef STREAMING |
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
21 #include "network.h" |
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
22 #endif |
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
23 |
4314 | 24 #ifdef __FreeBSD__ |
25 #include "network.h" | |
26 #endif | |
27 | |
578 | 28 int vcd_seek_to_track(int fd,int track); |
29 void vcd_read_toc(int fd); | |
30 | |
31 #ifdef VCD_CACHE | |
32 void vcd_cache_init(int s); | |
33 #endif | |
34 | |
35 typedef struct { | |
36 int fd; | |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
37 off_t pos; |
578 | 38 int eof; |
39 int type; // 0=file 1=VCD | |
40 unsigned int buf_pos,buf_len; | |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
41 off_t start_pos,end_pos; |
2322 | 42 unsigned int cache_pid; |
43 void* cache_data; | |
2144 | 44 void* priv; // used for DVD |
583 | 45 unsigned char buffer[STREAM_BUFFER_SIZE>VCD_SECTOR_SIZE?STREAM_BUFFER_SIZE:VCD_SECTOR_SIZE]; |
3043
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
46 #ifdef STREAMING |
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
47 streaming_ctrl_t *streaming_ctrl; |
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
48 #endif |
578 | 49 } stream_t; |
50 | |
2322 | 51 #ifdef USE_STREAM_CACHE |
3600 | 52 void stream_enable_cache(stream_t *stream,int size,int min,int prefill); |
2322 | 53 #else |
54 // no cache | |
55 #define cache_stream_fill_buffer(x) stream_fill_buffer(x) | |
56 #define cache_stream_seek_long(x,y) stream_seek_long(x,y) | |
57 #define stream_enable_cache(x,y) | |
58 #endif | |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
59 |
2322 | 60 int cache_stream_fill_buffer(stream_t *s); |
61 int cache_stream_seek_long(stream_t *s,off_t pos); | |
578 | 62 |
3726 | 63 #include <string.h> |
64 | |
578 | 65 inline static int stream_read_char(stream_t *s){ |
66 return (s->buf_pos<s->buf_len)?s->buffer[s->buf_pos++]: | |
2322 | 67 (cache_stream_fill_buffer(s)?s->buffer[s->buf_pos++]:-256); |
578 | 68 // if(s->buf_pos<s->buf_len) return s->buffer[s->buf_pos++]; |
69 // stream_fill_buffer(s); | |
70 // if(s->buf_pos<s->buf_len) return s->buffer[s->buf_pos++]; | |
71 // return 0; // EOF | |
72 } | |
73 | |
74 inline static unsigned int stream_read_word(stream_t *s){ | |
75 int x,y; | |
76 x=stream_read_char(s); | |
77 y=stream_read_char(s); | |
78 return (x<<8)|y; | |
79 } | |
80 | |
81 inline static unsigned int stream_read_dword(stream_t *s){ | |
82 unsigned int y; | |
83 y=stream_read_char(s); | |
84 y=(y<<8)|stream_read_char(s); | |
85 y=(y<<8)|stream_read_char(s); | |
86 y=(y<<8)|stream_read_char(s); | |
87 return y; | |
88 } | |
89 | |
4189 | 90 #define stream_read_fourcc stream_read_dword_le |
91 | |
578 | 92 inline static unsigned int stream_read_word_le(stream_t *s){ |
93 int x,y; | |
94 x=stream_read_char(s); | |
95 y=stream_read_char(s); | |
96 return (y<<8)|x; | |
97 } | |
98 | |
99 inline static unsigned int stream_read_dword_le(stream_t *s){ | |
100 unsigned int y; | |
101 y=stream_read_char(s); | |
102 y|=stream_read_char(s)<<8; | |
103 y|=stream_read_char(s)<<16; | |
104 y|=stream_read_char(s)<<24; | |
105 return y; | |
106 } | |
107 | |
3998 | 108 inline static uint64_t stream_read_qword(stream_t *s){ |
109 uint64_t y; | |
110 y = stream_read_char(s); | |
111 y=(y<<8)|stream_read_char(s); | |
112 y=(y<<8)|stream_read_char(s); | |
113 y=(y<<8)|stream_read_char(s); | |
114 y=(y<<8)|stream_read_char(s); | |
115 y=(y<<8)|stream_read_char(s); | |
116 y=(y<<8)|stream_read_char(s); | |
117 y=(y<<8)|stream_read_char(s); | |
118 return y; | |
119 } | |
120 | |
2347 | 121 inline static int stream_read(stream_t *s,char* mem,int total){ |
122 int len=total; | |
578 | 123 while(len>0){ |
124 int x; | |
125 x=s->buf_len-s->buf_pos; | |
126 if(x==0){ | |
2347 | 127 if(!cache_stream_fill_buffer(s)) return total-len; // EOF |
578 | 128 x=s->buf_len-s->buf_pos; |
129 } | |
130 if(s->buf_pos>s->buf_len) printf("stream_read: WARNING! s->buf_pos>s->buf_len\n"); | |
131 if(x>len) x=len; | |
132 memcpy(mem,&s->buffer[s->buf_pos],x); | |
133 s->buf_pos+=x; mem+=x; len-=x; | |
134 } | |
2347 | 135 return total; |
578 | 136 } |
137 | |
138 inline static int stream_eof(stream_t *s){ | |
139 return s->eof; | |
140 } | |
141 | |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
142 inline static off_t stream_tell(stream_t *s){ |
578 | 143 return s->pos+s->buf_pos-s->buf_len; |
144 } | |
145 | |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
146 inline static int stream_seek(stream_t *s,off_t pos){ |
578 | 147 |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
148 // if(verbose>=3) printf("seek to 0x%qX\n",(long long)pos); |
578 | 149 |
150 if(pos<s->pos){ | |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
151 off_t x=pos-(s->pos-s->buf_len); |
578 | 152 if(x>=0){ |
153 s->buf_pos=x; | |
154 // putchar('*');fflush(stdout); | |
155 return 1; | |
156 } | |
157 } | |
158 | |
2322 | 159 return cache_stream_seek_long(s,pos); |
578 | 160 } |
161 | |
3962 | 162 inline static int stream_skip(stream_t *s,off_t len){ |
692 | 163 if(len<0 || (len>2*STREAM_BUFFER_SIZE && s->type!=STREAMTYPE_STREAM)){ |
578 | 164 // negative or big skip! |
1491 | 165 return stream_seek(s,stream_tell(s)+len); |
578 | 166 } |
167 while(len>0){ | |
168 int x=s->buf_len-s->buf_pos; | |
169 if(x==0){ | |
2322 | 170 if(!cache_stream_fill_buffer(s)) return 0; // EOF |
578 | 171 x=s->buf_len-s->buf_pos; |
172 } | |
173 if(x>len) x=len; | |
174 //memcpy(mem,&s->buf[s->buf_pos],x); | |
175 s->buf_pos+=x; len-=x; | |
176 } | |
1491 | 177 return 1; |
578 | 178 } |
179 | |
180 void stream_reset(stream_t *s); | |
181 stream_t* new_stream(int fd,int type); | |
182 void free_stream(stream_t *s); | |
2144 | 183 stream_t* new_memory_stream(unsigned char* data,int len); |
2555
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
184 stream_t* open_stream(char* filename,int vcd_track,int* file_format); |
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
185 |
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
186 //#ifdef USE_DVDREAD |
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
187 extern int dvd_title; |
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
188 extern int dvd_chapter; |
4291
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4189
diff
changeset
|
189 extern int dvd_last_chapter; |
2555
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
190 extern int dvd_angle; |
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
191 //#endif |
998
8c83e3ff26cc
Added ifndef to prevent multiple header file inclusion.
bertrand
parents:
692
diff
changeset
|
192 |
2935 | 193 #ifdef USE_DVDREAD |
194 | |
195 #include <dvdread/dvd_reader.h> | |
196 #include <dvdread/ifo_types.h> | |
197 #include <dvdread/ifo_read.h> | |
198 #include <dvdread/nav_read.h> | |
199 | |
200 typedef struct { | |
201 int id; // 0 - 31 mpeg; 128 - 159 ac3; 160 - 191 pcm | |
202 int language; | |
3751
d9d2ee82a243
subtitle_t + audio_stream_t -> stream_language_t (cleanup)
arpi
parents:
3726
diff
changeset
|
203 } stream_language_t; |
3048 | 204 |
205 typedef struct { | |
2935 | 206 dvd_reader_t *dvd; |
207 dvd_file_t *title; | |
208 ifo_handle_t *vmg_file; | |
209 tt_srpt_t *tt_srpt; | |
210 ifo_handle_t *vts_file; | |
211 vts_ptt_srpt_t *vts_ptt_srpt; | |
212 pgc_t *cur_pgc; | |
213 // | |
214 int cur_cell; | |
4291
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4189
diff
changeset
|
215 int last_cell; |
2935 | 216 int cur_pack; |
217 int cell_last_pack; | |
218 // Navi: | |
219 int packs_left; | |
220 dsi_t dsi_pack; | |
221 int angle_seek; | |
222 // audio datas | |
223 int nr_of_channels; | |
3751
d9d2ee82a243
subtitle_t + audio_stream_t -> stream_language_t (cleanup)
arpi
parents:
3726
diff
changeset
|
224 stream_language_t audio_streams[32]; |
3048 | 225 // subtitles |
226 int nr_of_subtitles; | |
3751
d9d2ee82a243
subtitle_t + audio_stream_t -> stream_language_t (cleanup)
arpi
parents:
3726
diff
changeset
|
227 stream_language_t subtitles[32]; |
2935 | 228 } dvd_priv_t; |
229 | |
3753 | 230 int dvd_aid_from_lang(stream_t *stream, unsigned char* lang); |
231 int dvd_sid_from_lang(stream_t *stream, unsigned char* lang); | |
232 | |
2935 | 233 #endif |
234 | |
998
8c83e3ff26cc
Added ifndef to prevent multiple header file inclusion.
bertrand
parents:
692
diff
changeset
|
235 #endif // __STREAM_H |