Mercurial > mplayer.hg
annotate stream/stream.h @ 19565:5275c455ddfb
Add missing backslashes.
author | diego |
---|---|
date | Mon, 28 Aug 2006 16:26:11 +0000 |
parents | 1f117b5fb5a1 |
children | bd821fd3e244 |
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 |
5086 | 4 #include "mp_msg.h" |
7412
ecef4f2191b2
some cosmetics - reordering declarations, 10l for cache2
arpi
parents:
7408
diff
changeset
|
5 #include <string.h> |
4029
3c87dee7a324
patch for missing include by Steven M. Schultz <sms@2BSD.COM>
pl
parents:
3998
diff
changeset
|
6 #include <inttypes.h> |
5292 | 7 #include <sys/types.h> |
4029
3c87dee7a324
patch for missing include by Steven M. Schultz <sms@2BSD.COM>
pl
parents:
3998
diff
changeset
|
8 |
7407 | 9 #define STREAMTYPE_DUMMY -1 // for placeholders, when the actual reading is handled in the demuxer |
10 #define STREAMTYPE_FILE 0 // read from seekable file | |
11 #define STREAMTYPE_VCD 1 // raw mode-2 CDROM reading, 2324 bytes/sector | |
12 #define STREAMTYPE_STREAM 2 // same as FILE but no seeking (for net/stdin) | |
13 #define STREAMTYPE_DVD 3 // libdvdread | |
14 #define STREAMTYPE_MEMORY 4 // read data from memory area | |
15 #define STREAMTYPE_PLAYLIST 6 // FIXME!!! same as STREAMTYPE_FILE now | |
16 #define STREAMTYPE_DS 8 // read from a demuxer stream | |
17 #define STREAMTYPE_DVDNAV 9 // we cannot safely "seek" in this... | |
18 #define STREAMTYPE_CDDA 10 // raw audio CD reader | |
7630
4c51ce16c4a2
smb:// (samba client) support by Vladimir Moushkov <vlindos_mpdev@abv.bg>
arpi
parents:
7412
diff
changeset
|
19 #define STREAMTYPE_SMB 11 // smb:// url, using libsmbclient (samba) |
8782
6af7a6595cc9
cdrwin-style bin/cue VCD image support (-vcd <track> -cuefile file.cue)
arpi
parents:
8164
diff
changeset
|
20 #define STREAMTYPE_VCDBINCUE 12 // vcd directly from bin/cue files |
9610 | 21 #define STREAMTYPE_DVB 13 |
14836
8b9738526dd7
added a stream module for the vstream client library
joey
parents:
13089
diff
changeset
|
22 #define STREAMTYPE_VSTREAM 14 |
15585 | 23 #define STREAMTYPE_SDP 15 |
18997 | 24 #define STREAMTYPE_PVR 16 |
19295
f6316aa3a7f2
conversion from stream_null to stream_tv was missing stream type
ben
parents:
19271
diff
changeset
|
25 #define STREAMTYPE_TV 17 |
19301 | 26 #define STREAMTYPE_MF 18 |
578 | 27 |
7412
ecef4f2191b2
some cosmetics - reordering declarations, 10l for cache2
arpi
parents:
7408
diff
changeset
|
28 #define STREAM_BUFFER_SIZE 2048 |
ecef4f2191b2
some cosmetics - reordering declarations, 10l for cache2
arpi
parents:
7408
diff
changeset
|
29 |
578 | 30 #define VCD_SECTOR_SIZE 2352 |
31 #define VCD_SECTOR_OFFS 24 | |
32 #define VCD_SECTOR_DATA 2324 | |
33 | |
9794 | 34 /// atm it will always use mode == STREAM_READ |
35 /// streams that use the new api should check the mode at open | |
36 #define STREAM_READ 0 | |
37 #define STREAM_WRITE 1 | |
38 /// Seek flags, if not mannualy set and s->seek isn't NULL | |
39 /// STREAM_SEEK is automaticly set | |
40 #define STREAM_SEEK_BW 2 | |
41 #define STREAM_SEEK_FW 4 | |
42 #define STREAM_SEEK (STREAM_SEEK_BW|STREAM_SEEK_FW) | |
43 | |
44 //////////// Open return code | |
45 /// This can't open the requested protocol (used by stream wich have a | |
46 /// * protocol when they don't know the requested protocol) | |
47 #define STREAM_UNSUPORTED -1 | |
48 #define STREAM_ERROR 0 | |
49 #define STREAM_OK 1 | |
50 | |
51 #define MAX_STREAM_PROTOCOLS 10 | |
52 | |
9851 | 53 #define STREAM_CTRL_RESET 0 |
17696
66d7afee9a46
added new stream_control() and new command: STREAM_CTRL_GET_TIME_LENGTH
nicodvb
parents:
17012
diff
changeset
|
54 #define STREAM_CTRL_GET_TIME_LENGTH 1 |
19434
f2da98669a77
new STREAM_CTRL_SEEK_TO_CHAPTER (will be used by streams dvd[nav], maybe [s]vcd
nicodvb
parents:
19301
diff
changeset
|
55 #define STREAM_CTRL_SEEK_TO_CHAPTER 2 |
19437
c73bf418b291
new stream_ctrl to get currently playing chapter (needed for stream-driven relative chapter seeking)
nicodvb
parents:
19434
diff
changeset
|
56 #define STREAM_CTRL_GET_CURRENT_CHAPTER 3 |
19475
1f117b5fb5a1
added STREAM_CTRL_GET_NUM_CHAPTERS to get total number of chapters from the stream reader
nicodvb
parents:
19437
diff
changeset
|
57 #define STREAM_CTRL_GET_NUM_CHAPTERS 4 |
9794 | 58 |
10121
d42177a0da2a
Changed the STREAMING defines to MPLAYER_NETWORK to avoid name definition clash.
bertrand
parents:
9886
diff
changeset
|
59 #ifdef MPLAYER_NETWORK |
3043
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
60 #include "network.h" |
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
61 #endif |
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
62 |
9794 | 63 struct stream_st; |
64 typedef struct stream_info_st { | |
65 const char *info; | |
66 const char *name; | |
67 const char *author; | |
68 const char *comment; | |
69 /// mode isn't used atm (ie always READ) but it shouldn't be ignored | |
70 /// opts is at least in it's defaults settings and may have been | |
71 /// altered by url parsing if enabled and the options string parsing. | |
72 int (*open)(struct stream_st* st, int mode, void* opts, int* file_format); | |
73 char* protocols[MAX_STREAM_PROTOCOLS]; | |
74 void* opts; | |
75 int opts_url; /* If this is 1 we will parse the url as an option string | |
76 * too. Otherwise options are only parsed from the | |
77 * options string given to open_stream_plugin */ | |
78 } stream_info_t; | |
79 | |
8164
487cfc28525d
New config system + cleanup of header inter dependency
albeu
parents:
7854
diff
changeset
|
80 typedef struct stream_st { |
9794 | 81 // Read |
82 int (*fill_buffer)(struct stream_st *s, char* buffer, int max_len); | |
83 // Write | |
84 int (*write_buffer)(struct stream_st *s, char* buffer, int len); | |
85 // Seek | |
86 int (*seek)(struct stream_st *s,off_t pos); | |
87 // Control | |
88 // Will be later used to let streams like dvd and cdda report | |
89 // their structure (ie tracks, chapters, etc) | |
90 int (*control)(struct stream_st *s,int cmd,void* arg); | |
91 // Close | |
92 void (*close)(struct stream_st *s); | |
93 | |
7407 | 94 int fd; // file descriptor, see man open(2) |
95 int type; // see STREAMTYPE_* | |
9794 | 96 int flags; |
97 int sector_size; // sector size (seek will be aligned on this size if non 0) | |
578 | 98 unsigned int buf_pos,buf_len; |
6224
79b2b4c3c435
off_t fields reordered, to avoid problems due to struct padding
arpi
parents:
5819
diff
changeset
|
99 off_t pos,start_pos,end_pos; |
79b2b4c3c435
off_t fields reordered, to avoid problems due to struct padding
arpi
parents:
5819
diff
changeset
|
100 int eof; |
2322 | 101 unsigned int cache_pid; |
102 void* cache_data; | |
7329
9129781e5939
removed messy global 'tv_handle', use stream->priv for that purpose
arpi
parents:
7245
diff
changeset
|
103 void* priv; // used for DVD, TV, RTSP etc |
7407 | 104 char* url; // strdup() of filename/url |
10121
d42177a0da2a
Changed the STREAMING defines to MPLAYER_NETWORK to avoid name definition clash.
bertrand
parents:
9886
diff
changeset
|
105 #ifdef MPLAYER_NETWORK |
3043
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
106 streaming_ctrl_t *streaming_ctrl; |
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
107 #endif |
7407 | 108 unsigned char buffer[STREAM_BUFFER_SIZE>VCD_SECTOR_SIZE?STREAM_BUFFER_SIZE:VCD_SECTOR_SIZE]; |
578 | 109 } stream_t; |
110 | |
2322 | 111 #ifdef USE_STREAM_CACHE |
4825
41d2da3bd082
Make blocking call in libmpdemux interuptable (only with new input,
albeu
parents:
4551
diff
changeset
|
112 int stream_enable_cache(stream_t *stream,int size,int min,int prefill); |
7412
ecef4f2191b2
some cosmetics - reordering declarations, 10l for cache2
arpi
parents:
7408
diff
changeset
|
113 int cache_stream_fill_buffer(stream_t *s); |
ecef4f2191b2
some cosmetics - reordering declarations, 10l for cache2
arpi
parents:
7408
diff
changeset
|
114 int cache_stream_seek_long(stream_t *s,off_t pos); |
2322 | 115 #else |
7412
ecef4f2191b2
some cosmetics - reordering declarations, 10l for cache2
arpi
parents:
7408
diff
changeset
|
116 // no cache, define wrappers: |
2322 | 117 #define cache_stream_fill_buffer(x) stream_fill_buffer(x) |
118 #define cache_stream_seek_long(x,y) stream_seek_long(x,y) | |
5292 | 119 #define stream_enable_cache(x,y,z,w) 1 |
2322 | 120 #endif |
15954 | 121 void fixup_network_stream_cache(stream_t *stream); |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
122 |
578 | 123 inline static int stream_read_char(stream_t *s){ |
124 return (s->buf_pos<s->buf_len)?s->buffer[s->buf_pos++]: | |
2322 | 125 (cache_stream_fill_buffer(s)?s->buffer[s->buf_pos++]:-256); |
578 | 126 // if(s->buf_pos<s->buf_len) return s->buffer[s->buf_pos++]; |
127 // stream_fill_buffer(s); | |
128 // if(s->buf_pos<s->buf_len) return s->buffer[s->buf_pos++]; | |
129 // return 0; // EOF | |
130 } | |
131 | |
132 inline static unsigned int stream_read_word(stream_t *s){ | |
133 int x,y; | |
134 x=stream_read_char(s); | |
135 y=stream_read_char(s); | |
136 return (x<<8)|y; | |
137 } | |
138 | |
139 inline static unsigned int stream_read_dword(stream_t *s){ | |
140 unsigned int y; | |
141 y=stream_read_char(s); | |
142 y=(y<<8)|stream_read_char(s); | |
143 y=(y<<8)|stream_read_char(s); | |
144 y=(y<<8)|stream_read_char(s); | |
145 return y; | |
146 } | |
147 | |
4189 | 148 #define stream_read_fourcc stream_read_dword_le |
149 | |
578 | 150 inline static unsigned int stream_read_word_le(stream_t *s){ |
151 int x,y; | |
152 x=stream_read_char(s); | |
153 y=stream_read_char(s); | |
154 return (y<<8)|x; | |
155 } | |
156 | |
157 inline static unsigned int stream_read_dword_le(stream_t *s){ | |
158 unsigned int y; | |
159 y=stream_read_char(s); | |
160 y|=stream_read_char(s)<<8; | |
161 y|=stream_read_char(s)<<16; | |
162 y|=stream_read_char(s)<<24; | |
163 return y; | |
164 } | |
165 | |
3998 | 166 inline static uint64_t stream_read_qword(stream_t *s){ |
167 uint64_t y; | |
168 y = stream_read_char(s); | |
169 y=(y<<8)|stream_read_char(s); | |
170 y=(y<<8)|stream_read_char(s); | |
171 y=(y<<8)|stream_read_char(s); | |
172 y=(y<<8)|stream_read_char(s); | |
173 y=(y<<8)|stream_read_char(s); | |
174 y=(y<<8)|stream_read_char(s); | |
175 y=(y<<8)|stream_read_char(s); | |
176 return y; | |
177 } | |
178 | |
11807
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
179 inline static uint64_t stream_read_qword_le(stream_t *s){ |
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
180 uint64_t y; |
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
181 y = stream_read_char(s); |
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
182 y|=stream_read_char(s)<<8; |
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
183 y|=stream_read_char(s)<<16; |
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
184 y|=stream_read_char(s)<<24; |
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
185 y|=(uint64_t)stream_read_char(s)<<32; |
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
186 y|=(uint64_t)stream_read_char(s)<<40; |
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
187 y|=(uint64_t)stream_read_char(s)<<48; |
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
188 y|=(uint64_t)stream_read_char(s)<<56; |
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
189 return y; |
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
190 } |
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
191 |
5301 | 192 inline static unsigned int stream_read_int24(stream_t *s){ |
193 unsigned int y; | |
194 y = stream_read_char(s); | |
195 y=(y<<8)|stream_read_char(s); | |
196 y=(y<<8)|stream_read_char(s); | |
197 return y; | |
198 } | |
199 | |
2347 | 200 inline static int stream_read(stream_t *s,char* mem,int total){ |
201 int len=total; | |
578 | 202 while(len>0){ |
203 int x; | |
204 x=s->buf_len-s->buf_pos; | |
205 if(x==0){ | |
2347 | 206 if(!cache_stream_fill_buffer(s)) return total-len; // EOF |
578 | 207 x=s->buf_len-s->buf_pos; |
208 } | |
5086 | 209 if(s->buf_pos>s->buf_len) mp_msg(MSGT_DEMUX, MSGL_WARN, "stream_read: WARNING! s->buf_pos>s->buf_len\n"); |
578 | 210 if(x>len) x=len; |
211 memcpy(mem,&s->buffer[s->buf_pos],x); | |
212 s->buf_pos+=x; mem+=x; len-=x; | |
213 } | |
2347 | 214 return total; |
578 | 215 } |
216 | |
17879 | 217 inline static unsigned char* stream_read_line(stream_t *s,unsigned char* mem, int max) { |
218 int len; | |
219 unsigned char* end,*ptr = mem;; | |
220 do { | |
221 len = s->buf_len-s->buf_pos; | |
222 // try to fill the buffer | |
223 if(len <= 0 && | |
224 (!cache_stream_fill_buffer(s) || | |
225 (len = s->buf_len-s->buf_pos) <= 0)) break; | |
17880
c0fa48581ccf
Fix compilation with stupid C++ compilers that shock on valid C
albeu
parents:
17879
diff
changeset
|
226 end = (unsigned char*) memchr((void*)(s->buffer+s->buf_pos),'\n',len); |
17879 | 227 if(end) len = end - (s->buffer+s->buf_pos) + 1; |
228 if(len > 0 && max > 1) { | |
229 int l = len > max-1 ? max-1 : len; | |
230 memcpy(ptr,s->buffer+s->buf_pos,l); | |
231 max -= l; | |
232 ptr += l; | |
233 } | |
234 s->buf_pos += len; | |
235 } while(!end); | |
236 if(s->eof && ptr == mem) return NULL; | |
237 if(max > 0) ptr[0] = 0; | |
238 return mem; | |
239 } | |
240 | |
241 | |
578 | 242 inline static int stream_eof(stream_t *s){ |
243 return s->eof; | |
244 } | |
245 | |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
246 inline static off_t stream_tell(stream_t *s){ |
578 | 247 return s->pos+s->buf_pos-s->buf_len; |
248 } | |
249 | |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
250 inline static int stream_seek(stream_t *s,off_t pos){ |
578 | 251 |
5086 | 252 mp_dbg(MSGT_DEMUX, MSGL_DBG3, "seek to 0x%qX\n",(long long)pos); |
578 | 253 |
254 if(pos<s->pos){ | |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
255 off_t x=pos-(s->pos-s->buf_len); |
578 | 256 if(x>=0){ |
257 s->buf_pos=x; | |
258 // putchar('*');fflush(stdout); | |
259 return 1; | |
260 } | |
261 } | |
262 | |
2322 | 263 return cache_stream_seek_long(s,pos); |
578 | 264 } |
265 | |
3962 | 266 inline static int stream_skip(stream_t *s,off_t len){ |
12018 | 267 if( (len<0 && (s->flags & STREAM_SEEK_BW)) || (len>2*STREAM_BUFFER_SIZE && (s->flags & STREAM_SEEK_FW)) ) { |
578 | 268 // negative or big skip! |
1491 | 269 return stream_seek(s,stream_tell(s)+len); |
578 | 270 } |
271 while(len>0){ | |
272 int x=s->buf_len-s->buf_pos; | |
273 if(x==0){ | |
2322 | 274 if(!cache_stream_fill_buffer(s)) return 0; // EOF |
578 | 275 x=s->buf_len-s->buf_pos; |
276 } | |
277 if(x>len) x=len; | |
278 //memcpy(mem,&s->buf[s->buf_pos],x); | |
279 s->buf_pos+=x; len-=x; | |
280 } | |
1491 | 281 return 1; |
578 | 282 } |
283 | |
284 void stream_reset(stream_t *s); | |
17712 | 285 int stream_control(stream_t *s, int cmd, void *arg); |
578 | 286 stream_t* new_stream(int fd,int type); |
287 void free_stream(stream_t *s); | |
2144 | 288 stream_t* new_memory_stream(unsigned char* data,int len); |
9794 | 289 stream_t* open_stream(char* filename,char** options,int* file_format); |
290 stream_t* open_stream_full(char* filename,int mode, char** options, int* file_format); | |
2555
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
291 |
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
292 extern int dvd_title; |
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
293 extern int dvd_chapter; |
4291
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4189
diff
changeset
|
294 extern int dvd_last_chapter; |
2555
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
295 extern int dvd_angle; |
998
8c83e3ff26cc
Added ifndef to prevent multiple header file inclusion.
bertrand
parents:
692
diff
changeset
|
296 |
6623 | 297 extern char * audio_stream; |
298 | |
2935 | 299 typedef struct { |
300 int id; // 0 - 31 mpeg; 128 - 159 ac3; 160 - 191 pcm | |
301 int language; | |
6651 | 302 int type; |
303 int channels; | |
3751
d9d2ee82a243
subtitle_t + audio_stream_t -> stream_language_t (cleanup)
arpi
parents:
3726
diff
changeset
|
304 } stream_language_t; |
3048 | 305 |
998
8c83e3ff26cc
Added ifndef to prevent multiple header file inclusion.
bertrand
parents:
692
diff
changeset
|
306 #endif // __STREAM_H |