Mercurial > mplayer.hg
annotate stream/stream.h @ 30626:27b133678bbd
Do not discard stream buffer on eof, instead reuse it to slightly improve
format autodetection with -nocache and non-seekable streams.
author | reimar |
---|---|
date | Sat, 20 Feb 2010 18:53:07 +0000 |
parents | ce0122361a39 |
children | 77cc0ca2c757 |
rev | line source |
---|---|
30426
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
1 /* |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
2 * This file is part of MPlayer. |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
3 * |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
4 * MPlayer is free software; you can redistribute it and/or modify |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
5 * it under the terms of the GNU General Public License as published by |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
6 * the Free Software Foundation; either version 2 of the License, or |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
7 * (at your option) any later version. |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
8 * |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
9 * MPlayer is distributed in the hope that it will be useful, |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
12 * GNU General Public License for more details. |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
13 * |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
14 * You should have received a copy of the GNU General Public License along |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
15 * with MPlayer; if not, write to the Free Software Foundation, Inc., |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
16 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
17 */ |
ce0122361a39
Add license header to all files missing it in the stream subdirectory.
diego
parents:
30165
diff
changeset
|
18 |
26029 | 19 #ifndef MPLAYER_STREAM_H |
20 #define MPLAYER_STREAM_H | |
578 | 21 |
30165 | 22 #include "config.h" |
5086 | 23 #include "mp_msg.h" |
7412
ecef4f2191b2
some cosmetics - reordering declarations, 10l for cache2
arpi
parents:
7408
diff
changeset
|
24 #include <string.h> |
4029
3c87dee7a324
patch for missing include by Steven M. Schultz <sms@2BSD.COM>
pl
parents:
3998
diff
changeset
|
25 #include <inttypes.h> |
5292 | 26 #include <sys/types.h> |
4029
3c87dee7a324
patch for missing include by Steven M. Schultz <sms@2BSD.COM>
pl
parents:
3998
diff
changeset
|
27 |
7407 | 28 #define STREAMTYPE_DUMMY -1 // for placeholders, when the actual reading is handled in the demuxer |
29 #define STREAMTYPE_FILE 0 // read from seekable file | |
30 #define STREAMTYPE_VCD 1 // raw mode-2 CDROM reading, 2324 bytes/sector | |
31 #define STREAMTYPE_STREAM 2 // same as FILE but no seeking (for net/stdin) | |
32 #define STREAMTYPE_DVD 3 // libdvdread | |
33 #define STREAMTYPE_MEMORY 4 // read data from memory area | |
34 #define STREAMTYPE_PLAYLIST 6 // FIXME!!! same as STREAMTYPE_FILE now | |
35 #define STREAMTYPE_DS 8 // read from a demuxer stream | |
36 #define STREAMTYPE_DVDNAV 9 // we cannot safely "seek" in this... | |
37 #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
|
38 #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
|
39 #define STREAMTYPE_VCDBINCUE 12 // vcd directly from bin/cue files |
9610 | 40 #define STREAMTYPE_DVB 13 |
14836
8b9738526dd7
added a stream module for the vstream client library
joey
parents:
13089
diff
changeset
|
41 #define STREAMTYPE_VSTREAM 14 |
15585 | 42 #define STREAMTYPE_SDP 15 |
18997 | 43 #define STREAMTYPE_PVR 16 |
19295
f6316aa3a7f2
conversion from stream_null to stream_tv was missing stream type
ben
parents:
19271
diff
changeset
|
44 #define STREAMTYPE_TV 17 |
19301 | 45 #define STREAMTYPE_MF 18 |
19568
bd821fd3e244
Radio support, patch by Vladimir Voroshilov (voroshil gmail com)
reimar
parents:
19475
diff
changeset
|
46 #define STREAMTYPE_RADIO 19 |
578 | 47 |
7412
ecef4f2191b2
some cosmetics - reordering declarations, 10l for cache2
arpi
parents:
7408
diff
changeset
|
48 #define STREAM_BUFFER_SIZE 2048 |
ecef4f2191b2
some cosmetics - reordering declarations, 10l for cache2
arpi
parents:
7408
diff
changeset
|
49 |
578 | 50 #define VCD_SECTOR_SIZE 2352 |
51 #define VCD_SECTOR_OFFS 24 | |
52 #define VCD_SECTOR_DATA 2324 | |
53 | |
9794 | 54 /// atm it will always use mode == STREAM_READ |
55 /// streams that use the new api should check the mode at open | |
56 #define STREAM_READ 0 | |
57 #define STREAM_WRITE 1 | |
58 /// Seek flags, if not mannualy set and s->seek isn't NULL | |
29920
4f740437ed2b
Finally rename the STREAM_SEEK define to MP_STREAM_SEEK, there are just too many
reimar
parents:
29888
diff
changeset
|
59 /// MP_STREAM_SEEK is automaticly set |
4f740437ed2b
Finally rename the STREAM_SEEK define to MP_STREAM_SEEK, there are just too many
reimar
parents:
29888
diff
changeset
|
60 #define MP_STREAM_SEEK_BW 2 |
4f740437ed2b
Finally rename the STREAM_SEEK define to MP_STREAM_SEEK, there are just too many
reimar
parents:
29888
diff
changeset
|
61 #define MP_STREAM_SEEK_FW 4 |
4f740437ed2b
Finally rename the STREAM_SEEK define to MP_STREAM_SEEK, there are just too many
reimar
parents:
29888
diff
changeset
|
62 #define MP_STREAM_SEEK (MP_STREAM_SEEK_BW|MP_STREAM_SEEK_FW) |
29888
5c39c41f38e8
Deobfuscate the special hack to disable cache for live555.
reimar
parents:
29263
diff
changeset
|
63 /** This is a HACK for live555 that does not respect the |
5c39c41f38e8
Deobfuscate the special hack to disable cache for live555.
reimar
parents:
29263
diff
changeset
|
64 separation between stream an demuxer and thus is not |
5c39c41f38e8
Deobfuscate the special hack to disable cache for live555.
reimar
parents:
29263
diff
changeset
|
65 actually a stream cache can not be used */ |
5c39c41f38e8
Deobfuscate the special hack to disable cache for live555.
reimar
parents:
29263
diff
changeset
|
66 #define STREAM_NON_CACHEABLE 8 |
9794 | 67 |
68 //////////// Open return code | |
25135
66f628d13442
Support stream redirection from http to mms, fix bug #927.
ulion
parents:
24297
diff
changeset
|
69 #define STREAM_REDIRECTED -2 |
9794 | 70 /// This can't open the requested protocol (used by stream wich have a |
71 /// * protocol when they don't know the requested protocol) | |
24257 | 72 #define STREAM_UNSUPPORTED -1 |
9794 | 73 #define STREAM_ERROR 0 |
74 #define STREAM_OK 1 | |
75 | |
76 #define MAX_STREAM_PROTOCOLS 10 | |
77 | |
9851 | 78 #define STREAM_CTRL_RESET 0 |
17696
66d7afee9a46
added new stream_control() and new command: STREAM_CTRL_GET_TIME_LENGTH
nicodvb
parents:
17012
diff
changeset
|
79 #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
|
80 #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
|
81 #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
|
82 #define STREAM_CTRL_GET_NUM_CHAPTERS 4 |
20744
30091c3ad3cd
added definitions of STREAM_CTRL_GET_CURRENT_TIME STREAM_CTRL_SEEK_TO_TIME
nicodvb
parents:
19568
diff
changeset
|
83 #define STREAM_CTRL_GET_CURRENT_TIME 5 |
30091c3ad3cd
added definitions of STREAM_CTRL_GET_CURRENT_TIME STREAM_CTRL_SEEK_TO_TIME
nicodvb
parents:
19568
diff
changeset
|
84 #define STREAM_CTRL_SEEK_TO_TIME 6 |
21657
5f5ed194b54b
new STREAM_CTRL_GET_SIZE to get size of output stream
nicodvb
parents:
21655
diff
changeset
|
85 #define STREAM_CTRL_GET_SIZE 7 |
24297
a5ae2d4973b8
introduced STREAM_CTRL_GET_ASPECT_RATIO to report the aspect ratio read from the stream layer (if supported)
nicodvb
parents:
24257
diff
changeset
|
86 #define STREAM_CTRL_GET_ASPECT_RATIO 8 |
25572
f6c0bce13b17
NEW STREAM_CTRLs: STREAM_CTRL_GET_NUM_ANGLES STREAM_CTRL_GET_ANGLE STREAM_CTRL_SET_ANGLE
nicodvb
parents:
25547
diff
changeset
|
87 #define STREAM_CTRL_GET_NUM_ANGLES 9 |
f6c0bce13b17
NEW STREAM_CTRLs: STREAM_CTRL_GET_NUM_ANGLES STREAM_CTRL_GET_ANGLE STREAM_CTRL_SET_ANGLE
nicodvb
parents:
25547
diff
changeset
|
88 #define STREAM_CTRL_GET_ANGLE 10 |
f6c0bce13b17
NEW STREAM_CTRLs: STREAM_CTRL_GET_NUM_ANGLES STREAM_CTRL_GET_ANGLE STREAM_CTRL_SET_ANGLE
nicodvb
parents:
25547
diff
changeset
|
89 #define STREAM_CTRL_SET_ANGLE 11 |
9794 | 90 |
27753
6c915906bbc6
Move DEFAULT_CDROM_DEVICE/DEFAULT_DVD_DEVICE to stream.h where it belongs.
diego
parents:
27397
diff
changeset
|
91 |
27397
d47744b95b78
Give a CONFIG_ prefix to preprocessor directives that lacked one and
diego
parents:
27341
diff
changeset
|
92 #ifdef CONFIG_NETWORK |
3043
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
93 #include "network.h" |
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
94 #endif |
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
95 |
9794 | 96 struct stream_st; |
97 typedef struct stream_info_st { | |
98 const char *info; | |
99 const char *name; | |
100 const char *author; | |
101 const char *comment; | |
102 /// mode isn't used atm (ie always READ) but it shouldn't be ignored | |
103 /// opts is at least in it's defaults settings and may have been | |
104 /// altered by url parsing if enabled and the options string parsing. | |
105 int (*open)(struct stream_st* st, int mode, void* opts, int* file_format); | |
25690
7b66e1a132de
stream_info_t opts and protocols point to constant data as well.
reimar
parents:
25572
diff
changeset
|
106 const char* protocols[MAX_STREAM_PROTOCOLS]; |
7b66e1a132de
stream_info_t opts and protocols point to constant data as well.
reimar
parents:
25572
diff
changeset
|
107 const void* opts; |
9794 | 108 int opts_url; /* If this is 1 we will parse the url as an option string |
109 * too. Otherwise options are only parsed from the | |
110 * options string given to open_stream_plugin */ | |
111 } stream_info_t; | |
112 | |
8164
487cfc28525d
New config system + cleanup of header inter dependency
albeu
parents:
7854
diff
changeset
|
113 typedef struct stream_st { |
9794 | 114 // Read |
115 int (*fill_buffer)(struct stream_st *s, char* buffer, int max_len); | |
116 // Write | |
117 int (*write_buffer)(struct stream_st *s, char* buffer, int len); | |
118 // Seek | |
119 int (*seek)(struct stream_st *s,off_t pos); | |
120 // Control | |
121 // Will be later used to let streams like dvd and cdda report | |
122 // their structure (ie tracks, chapters, etc) | |
123 int (*control)(struct stream_st *s,int cmd,void* arg); | |
124 // Close | |
125 void (*close)(struct stream_st *s); | |
126 | |
7407 | 127 int fd; // file descriptor, see man open(2) |
128 int type; // see STREAMTYPE_* | |
9794 | 129 int flags; |
130 int sector_size; // sector size (seek will be aligned on this size if non 0) | |
578 | 131 unsigned int buf_pos,buf_len; |
6224
79b2b4c3c435
off_t fields reordered, to avoid problems due to struct padding
arpi
parents:
5819
diff
changeset
|
132 off_t pos,start_pos,end_pos; |
79b2b4c3c435
off_t fields reordered, to avoid problems due to struct padding
arpi
parents:
5819
diff
changeset
|
133 int eof; |
21655 | 134 int mode; //STREAM_READ or STREAM_WRITE |
2322 | 135 unsigned int cache_pid; |
136 void* cache_data; | |
7329
9129781e5939
removed messy global 'tv_handle', use stream->priv for that purpose
arpi
parents:
7245
diff
changeset
|
137 void* priv; // used for DVD, TV, RTSP etc |
7407 | 138 char* url; // strdup() of filename/url |
27397
d47744b95b78
Give a CONFIG_ prefix to preprocessor directives that lacked one and
diego
parents:
27341
diff
changeset
|
139 #ifdef CONFIG_NETWORK |
3043
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
140 streaming_ctrl_t *streaming_ctrl; |
02a43ca97b52
Added a new struct to stream_t to handle, network streaming.
bertrand
parents:
2935
diff
changeset
|
141 #endif |
7407 | 142 unsigned char buffer[STREAM_BUFFER_SIZE>VCD_SECTOR_SIZE?STREAM_BUFFER_SIZE:VCD_SECTOR_SIZE]; |
578 | 143 } stream_t; |
144 | |
27341
e7c989f7a7c9
Start unifying names of internal preprocessor directives.
diego
parents:
26326
diff
changeset
|
145 #ifdef CONFIG_STREAM_CACHE |
4825
41d2da3bd082
Make blocking call in libmpdemux interuptable (only with new input,
albeu
parents:
4551
diff
changeset
|
146 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
|
147 int cache_stream_fill_buffer(stream_t *s); |
ecef4f2191b2
some cosmetics - reordering declarations, 10l for cache2
arpi
parents:
7408
diff
changeset
|
148 int cache_stream_seek_long(stream_t *s,off_t pos); |
2322 | 149 #else |
7412
ecef4f2191b2
some cosmetics - reordering declarations, 10l for cache2
arpi
parents:
7408
diff
changeset
|
150 // no cache, define wrappers: |
22540
52c574919687
Fix live555 compilation when stream cache is disabled.
diego
parents:
21657
diff
changeset
|
151 int stream_fill_buffer(stream_t *s); |
52c574919687
Fix live555 compilation when stream cache is disabled.
diego
parents:
21657
diff
changeset
|
152 int stream_seek_long(stream_t *s,off_t pos); |
2322 | 153 #define cache_stream_fill_buffer(x) stream_fill_buffer(x) |
154 #define cache_stream_seek_long(x,y) stream_seek_long(x,y) | |
5292 | 155 #define stream_enable_cache(x,y,z,w) 1 |
2322 | 156 #endif |
15954 | 157 void fixup_network_stream_cache(stream_t *stream); |
21655 | 158 int stream_write_buffer(stream_t *s, unsigned char *buf, int len); |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
159 |
578 | 160 inline static int stream_read_char(stream_t *s){ |
161 return (s->buf_pos<s->buf_len)?s->buffer[s->buf_pos++]: | |
2322 | 162 (cache_stream_fill_buffer(s)?s->buffer[s->buf_pos++]:-256); |
578 | 163 // if(s->buf_pos<s->buf_len) return s->buffer[s->buf_pos++]; |
164 // stream_fill_buffer(s); | |
165 // if(s->buf_pos<s->buf_len) return s->buffer[s->buf_pos++]; | |
166 // return 0; // EOF | |
167 } | |
168 | |
169 inline static unsigned int stream_read_word(stream_t *s){ | |
170 int x,y; | |
171 x=stream_read_char(s); | |
172 y=stream_read_char(s); | |
173 return (x<<8)|y; | |
174 } | |
175 | |
176 inline static unsigned int stream_read_dword(stream_t *s){ | |
177 unsigned int y; | |
178 y=stream_read_char(s); | |
179 y=(y<<8)|stream_read_char(s); | |
180 y=(y<<8)|stream_read_char(s); | |
181 y=(y<<8)|stream_read_char(s); | |
182 return y; | |
183 } | |
184 | |
4189 | 185 #define stream_read_fourcc stream_read_dword_le |
186 | |
578 | 187 inline static unsigned int stream_read_word_le(stream_t *s){ |
188 int x,y; | |
189 x=stream_read_char(s); | |
190 y=stream_read_char(s); | |
191 return (y<<8)|x; | |
192 } | |
193 | |
194 inline static unsigned int stream_read_dword_le(stream_t *s){ | |
195 unsigned int y; | |
196 y=stream_read_char(s); | |
197 y|=stream_read_char(s)<<8; | |
198 y|=stream_read_char(s)<<16; | |
199 y|=stream_read_char(s)<<24; | |
200 return y; | |
201 } | |
202 | |
3998 | 203 inline static uint64_t stream_read_qword(stream_t *s){ |
204 uint64_t y; | |
205 y = stream_read_char(s); | |
206 y=(y<<8)|stream_read_char(s); | |
207 y=(y<<8)|stream_read_char(s); | |
208 y=(y<<8)|stream_read_char(s); | |
209 y=(y<<8)|stream_read_char(s); | |
210 y=(y<<8)|stream_read_char(s); | |
211 y=(y<<8)|stream_read_char(s); | |
212 y=(y<<8)|stream_read_char(s); | |
213 return y; | |
214 } | |
215 | |
11807
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
216 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
|
217 uint64_t y; |
24079
f40ff9321699
Fix a bug in stream_read_qword_le due to sign extension from int to uint64_t.
reimar
parents:
23689
diff
changeset
|
218 y = stream_read_dword_le(s); |
f40ff9321699
Fix a bug in stream_read_qword_le due to sign extension from int to uint64_t.
reimar
parents:
23689
diff
changeset
|
219 y|=(uint64_t)stream_read_dword_le(s)<<32; |
11807
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
220 return y; |
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
221 } |
9a81d7b4c0b6
Added the new C based Matroska demuxer by Aurelien Jacobs.
mosu
parents:
10594
diff
changeset
|
222 |
5301 | 223 inline static unsigned int stream_read_int24(stream_t *s){ |
224 unsigned int y; | |
225 y = stream_read_char(s); | |
226 y=(y<<8)|stream_read_char(s); | |
227 y=(y<<8)|stream_read_char(s); | |
228 return y; | |
229 } | |
230 | |
2347 | 231 inline static int stream_read(stream_t *s,char* mem,int total){ |
232 int len=total; | |
578 | 233 while(len>0){ |
234 int x; | |
235 x=s->buf_len-s->buf_pos; | |
236 if(x==0){ | |
2347 | 237 if(!cache_stream_fill_buffer(s)) return total-len; // EOF |
578 | 238 x=s->buf_len-s->buf_pos; |
239 } | |
5086 | 240 if(s->buf_pos>s->buf_len) mp_msg(MSGT_DEMUX, MSGL_WARN, "stream_read: WARNING! s->buf_pos>s->buf_len\n"); |
578 | 241 if(x>len) x=len; |
242 memcpy(mem,&s->buffer[s->buf_pos],x); | |
243 s->buf_pos+=x; mem+=x; len-=x; | |
244 } | |
2347 | 245 return total; |
578 | 246 } |
247 | |
17879 | 248 inline static unsigned char* stream_read_line(stream_t *s,unsigned char* mem, int max) { |
249 int len; | |
28576 | 250 unsigned char* end,*ptr = mem; |
17879 | 251 do { |
252 len = s->buf_len-s->buf_pos; | |
253 // try to fill the buffer | |
254 if(len <= 0 && | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28576
diff
changeset
|
255 (!cache_stream_fill_buffer(s) || |
17879 | 256 (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
|
257 end = (unsigned char*) memchr((void*)(s->buffer+s->buf_pos),'\n',len); |
17879 | 258 if(end) len = end - (s->buffer+s->buf_pos) + 1; |
259 if(len > 0 && max > 1) { | |
260 int l = len > max-1 ? max-1 : len; | |
261 memcpy(ptr,s->buffer+s->buf_pos,l); | |
262 max -= l; | |
263 ptr += l; | |
264 } | |
265 s->buf_pos += len; | |
266 } while(!end); | |
267 if(s->eof && ptr == mem) return NULL; | |
268 if(max > 0) ptr[0] = 0; | |
269 return mem; | |
270 } | |
271 | |
272 | |
578 | 273 inline static int stream_eof(stream_t *s){ |
274 return s->eof; | |
275 } | |
276 | |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
277 inline static off_t stream_tell(stream_t *s){ |
578 | 278 return s->pos+s->buf_pos-s->buf_len; |
279 } | |
280 | |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
281 inline static int stream_seek(stream_t *s,off_t pos){ |
578 | 282 |
5086 | 283 mp_dbg(MSGT_DEMUX, MSGL_DBG3, "seek to 0x%qX\n",(long long)pos); |
578 | 284 |
30626
27b133678bbd
Do not discard stream buffer on eof, instead reuse it to slightly improve
reimar
parents:
30426
diff
changeset
|
285 if(s->eof) |
27b133678bbd
Do not discard stream buffer on eof, instead reuse it to slightly improve
reimar
parents:
30426
diff
changeset
|
286 return 0; |
578 | 287 if(pos<s->pos){ |
1428
a90d889eb649
largefile patch by Stephen Davies <steve@daviesfam.org>
arpi
parents:
998
diff
changeset
|
288 off_t x=pos-(s->pos-s->buf_len); |
578 | 289 if(x>=0){ |
290 s->buf_pos=x; | |
291 // putchar('*');fflush(stdout); | |
292 return 1; | |
293 } | |
294 } | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28576
diff
changeset
|
295 |
2322 | 296 return cache_stream_seek_long(s,pos); |
578 | 297 } |
298 | |
3962 | 299 inline static int stream_skip(stream_t *s,off_t len){ |
29920
4f740437ed2b
Finally rename the STREAM_SEEK define to MP_STREAM_SEEK, there are just too many
reimar
parents:
29888
diff
changeset
|
300 if( (len<0 && (s->flags & MP_STREAM_SEEK_BW)) || (len>2*STREAM_BUFFER_SIZE && (s->flags & MP_STREAM_SEEK_FW)) ) { |
578 | 301 // negative or big skip! |
1491 | 302 return stream_seek(s,stream_tell(s)+len); |
578 | 303 } |
304 while(len>0){ | |
305 int x=s->buf_len-s->buf_pos; | |
306 if(x==0){ | |
2322 | 307 if(!cache_stream_fill_buffer(s)) return 0; // EOF |
578 | 308 x=s->buf_len-s->buf_pos; |
309 } | |
310 if(x>len) x=len; | |
311 //memcpy(mem,&s->buf[s->buf_pos],x); | |
312 s->buf_pos+=x; len-=x; | |
313 } | |
1491 | 314 return 1; |
578 | 315 } |
316 | |
317 void stream_reset(stream_t *s); | |
17712 | 318 int stream_control(stream_t *s, int cmd, void *arg); |
578 | 319 stream_t* new_stream(int fd,int type); |
320 void free_stream(stream_t *s); | |
2144 | 321 stream_t* new_memory_stream(unsigned char* data,int len); |
9794 | 322 stream_t* open_stream(char* filename,char** options,int* file_format); |
323 stream_t* open_stream_full(char* filename,int mode, char** options, int* file_format); | |
21655 | 324 stream_t* open_output_stream(char* filename,char** options); |
26326
5bfc1d8bece9
Remove the need for code using stream to export an mp_input_check_interrupt()
albeu
parents:
26029
diff
changeset
|
325 /// Set the callback to be used by libstream to check for user |
5bfc1d8bece9
Remove the need for code using stream to export an mp_input_check_interrupt()
albeu
parents:
26029
diff
changeset
|
326 /// interruption during long blocking operations (cache filling, etc). |
5bfc1d8bece9
Remove the need for code using stream to export an mp_input_check_interrupt()
albeu
parents:
26029
diff
changeset
|
327 void stream_set_interrupt_callback(int (*cb)(int)); |
5bfc1d8bece9
Remove the need for code using stream to export an mp_input_check_interrupt()
albeu
parents:
26029
diff
changeset
|
328 /// Call the interrupt checking callback if there is one. |
5bfc1d8bece9
Remove the need for code using stream to export an mp_input_check_interrupt()
albeu
parents:
26029
diff
changeset
|
329 int stream_check_interrupt(int time); |
2555
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
330 |
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
331 extern int dvd_title; |
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
332 extern int dvd_chapter; |
4291
e889d37f25b2
Add option -last-chapter for DVD playing/encoding
kmkaplan
parents:
4189
diff
changeset
|
333 extern int dvd_last_chapter; |
2555
66837325b929
config.h cleanup, few things added to steram/demuxer headers
arpi
parents:
2347
diff
changeset
|
334 extern int dvd_angle; |
998
8c83e3ff26cc
Added ifndef to prevent multiple header file inclusion.
bertrand
parents:
692
diff
changeset
|
335 |
6623 | 336 extern char * audio_stream; |
337 | |
2935 | 338 typedef struct { |
339 int id; // 0 - 31 mpeg; 128 - 159 ac3; 160 - 191 pcm | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
28576
diff
changeset
|
340 int language; |
6651 | 341 int type; |
342 int channels; | |
3751
d9d2ee82a243
subtitle_t + audio_stream_t -> stream_language_t (cleanup)
arpi
parents:
3726
diff
changeset
|
343 } stream_language_t; |
3048 | 344 |
26029 | 345 #endif /* MPLAYER_STREAM_H */ |