Mercurial > mplayer.hg
annotate libmpdemux/demux_nsv.c @ 32676:db882cd69776
Do not #define _WIN32 on the command line for Cygwin.
Newer Cygwin versions no longer do this and hopefully we should be able
to survive without this hack as well. This change necessitates adapting
two #ifdefs in the MPlayer codebase. It is committed untested as I do
not have access to a Cygwin system.
author | diego |
---|---|
date | Thu, 06 Jan 2011 12:42:59 +0000 |
parents | 8fa2f43cb760 |
children | cc8dfde2b6c5 |
rev | line source |
---|---|
12175 | 1 /* |
2 * Nullsoft Streaming Video demuxer | |
29238
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
3 * copyright (c) 2004 by Reza Jelveh <reza.jelveh@tuhh.de> |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
4 * Based on A'rpis G2 work |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
5 * |
12175 | 6 * seeking and PCM audio not yet supported |
7 * PCM needs extra audio chunk "miniheader" parsing | |
29238
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
8 * |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
9 * This file is part of MPlayer. |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
10 * |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
11 * MPlayer is free software; you can redistribute it and/or modify |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
12 * it under the terms of the GNU General Public License as published by |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
13 * the Free Software Foundation; either version 2 of the License, or |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
14 * (at your option) any later version. |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
15 * |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
16 * MPlayer is distributed in the hope that it will be useful, |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
19 * GNU General Public License for more details. |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
20 * |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
21 * You should have received a copy of the GNU General Public License along |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
22 * with MPlayer; if not, write to the Free Software Foundation, Inc., |
d643e4643313
Add standard license header to all files in libmpdemux.
diego
parents:
26295
diff
changeset
|
23 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. |
12175 | 24 */ |
25 | |
26 #include <stdio.h> | |
27 #include <stdlib.h> | |
28 #include <unistd.h> | |
29 | |
30 #include "config.h" | |
31 #include "mp_msg.h" | |
32 #include "help_mp.h" | |
22605
4d81dbdf46b9
Add explicit location for headers from the stream/ directory.
diego
parents:
20473
diff
changeset
|
33 #include "stream/stream.h" |
12175 | 34 #include "demuxer.h" |
35 #include "stheader.h" | |
36 | |
37 typedef struct { | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
38 float v_pts; |
12175 | 39 int video_pack_no; |
40 unsigned int a_format; | |
41 unsigned int v_format; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
42 unsigned char fps; |
12175 | 43 } nsv_priv_t; |
44 | |
18251
fdb789f1a99a
Increase HEADER_SEARCH_SIZE, fixes high-bitrate streams from demoscene.tv.
diego
parents:
17636
diff
changeset
|
45 #define HEADER_SEARCH_SIZE 256000 |
16318 | 46 |
47 | |
12175 | 48 /** |
49 * Seeking still to be implemented | |
50 */ | |
17636 | 51 static void demux_seek_nsv ( demuxer_t *demuxer, float rel_seek_secs, float audio_delay, int flags ) |
12175 | 52 { |
53 // seeking is not yet implemented | |
54 } | |
55 | |
56 | |
16175 | 57 static int demux_nsv_fill_buffer ( demuxer_t *demuxer, demux_stream_t *ds ) |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
58 { |
12175 | 59 unsigned char hdr[17]; |
60 // for the extra data | |
61 unsigned char aux[6]; | |
62 int i_aux = 0; | |
63 // videolen = audio chunk length, audiolen = video chunk length | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
64 int videolen,audiolen; |
12175 | 65 |
12272 | 66 sh_video_t *sh_video = demuxer->video->sh; |
67 sh_audio_t *sh_audio = demuxer->audio->sh; | |
12175 | 68 |
69 nsv_priv_t * priv = demuxer->priv; | |
70 | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
71 // if the audio/video chunk has no new header the first 2 bytes will be discarded 0xBEEF |
12175 | 72 // or rather 0xEF 0xBE |
73 stream_read(demuxer->stream,hdr,7); | |
74 if(stream_eof(demuxer->stream)) return 0; | |
75 // sometimes instead of 0xBEEF as described for the next audio/video chunk we get | |
76 // a whole new header | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
77 |
12175 | 78 mp_dbg(MSGT_DEMUX,MSGL_DBG2,"demux_nsv: %08X %08X\n",hdr[0]<<8|hdr[1],stream_tell(demuxer->stream)); |
79 switch(hdr[0]<<8|hdr[1]) { | |
80 case 0x4E53: | |
81 if(hdr[2]==0x56 && hdr[3]==0x73){ | |
82 // NSVs | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
83 // get the header since there is no more metaheader after the first one |
12175 | 84 // there is no more need to skip that |
85 stream_read(demuxer->stream,hdr+7,17-7); | |
86 stream_read(demuxer->stream,hdr,7); | |
87 } | |
88 break; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
89 |
12175 | 90 case 0xEFBE: |
91 break; | |
92 | |
93 default: | |
12272 | 94 mp_dbg(MSGT_DEMUX,MSGL_WARN,"demux_nsv: sync lost\n"); |
12175 | 95 break; |
96 } | |
97 | |
12272 | 98 if (sh_video) |
12175 | 99 sh_video->pts = priv->v_pts =demuxer->video->pts= priv->video_pack_no * |
100 (float)sh_video->frametime; | |
12272 | 101 else |
102 priv->v_pts = priv->video_pack_no; | |
12175 | 103 |
104 demuxer->filepos=stream_tell(demuxer->stream); | |
105 | |
106 | |
107 mp_dbg(MSGT_DEMUX,MSGL_DBG2,"demux_nsv: %08X: %02X %02X | %02X %02X %02X | %02X %02X \n", | |
108 (int)demuxer->filepos, hdr[0],hdr[1],hdr[2],hdr[3],hdr[4],hdr[5],hdr[6]); | |
109 | |
110 // read video: | |
111 videolen=(hdr[2]>>4)|(hdr[3]<<4)|(hdr[4]<<0xC); | |
112 //check if we got extra data like subtitles here | |
113 if( (hdr[2]&0x0f) != 0x0 ) { | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
114 stream_read( demuxer->stream, aux, 6); |
12175 | 115 |
116 i_aux = aux[0]|aux[1]<<8; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
117 // We skip this extra data |
12175 | 118 stream_skip( demuxer->stream, i_aux ); |
119 i_aux+=6; | |
120 videolen -= i_aux; | |
121 } | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
122 |
12175 | 123 |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
124 // we need to return an empty packet when the |
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
125 // video frame is empty otherwise the stream will fasten up |
12272 | 126 if(sh_video) { |
12175 | 127 if( (hdr[2]&0x0f) != 0x0 ) |
128 ds_read_packet(demuxer->video,demuxer->stream,videolen,priv->v_pts,demuxer->filepos-i_aux,0); | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
129 else |
12175 | 130 ds_read_packet(demuxer->video,demuxer->stream,videolen,priv->v_pts,demuxer->filepos,0); |
131 } | |
132 else | |
133 stream_skip(demuxer->stream,videolen); | |
134 | |
135 // read audio: | |
136 audiolen=(hdr[5])|(hdr[6]<<8); | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
137 // we need to return an empty packet when the |
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
138 // audio frame is empty otherwise the stream will fasten up |
12272 | 139 if(sh_audio) { |
12175 | 140 ds_read_packet(demuxer->audio,demuxer->stream,audiolen,priv->v_pts,demuxer->filepos+videolen,0); |
141 } | |
142 else | |
143 stream_skip(demuxer->stream,audiolen); | |
144 | |
145 ++priv->video_pack_no; | |
146 | |
147 return 1; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
148 |
12175 | 149 } |
150 | |
151 | |
16175 | 152 static demuxer_t* demux_open_nsv ( demuxer_t* demuxer ) |
12175 | 153 { |
154 // last 2 bytes 17 and 18 are unknown but right after that comes the length | |
155 unsigned char hdr[17]; | |
156 int videolen,audiolen; | |
12272 | 157 unsigned char buf[10]; |
12175 | 158 sh_video_t *sh_video = NULL; |
159 sh_audio_t *sh_audio = NULL; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
160 |
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
161 |
12175 | 162 nsv_priv_t * priv = malloc(sizeof(nsv_priv_t)); |
163 demuxer->priv=priv; | |
164 priv->video_pack_no=0; | |
165 | |
166 /* disable seeking yet to be fixed*/ | |
167 demuxer->seekable = 0; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
168 |
12175 | 169 stream_read(demuxer->stream,hdr,4); |
170 if(stream_eof(demuxer->stream)) return 0; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
171 |
12175 | 172 if(hdr[0]==0x4E && hdr[1]==0x53 && hdr[2]==0x56){ |
173 // NSV header! | |
174 if(hdr[3]==0x73){ | |
175 // NSVs | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
176 stream_read(demuxer->stream,hdr+4,17-4); |
12175 | 177 } |
178 | |
179 if(hdr[3]==0x66){ | |
180 // NSVf | |
181 int len=stream_read_dword_le(demuxer->stream); | |
182 // TODO: parse out metadata!!!! | |
183 stream_skip(demuxer->stream,len-8); | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
184 |
12175 | 185 // NSVs |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
186 stream_read(demuxer->stream,hdr,17); |
20470
054516eecb9b
Better check for non-broken NSVf-header to avoid incorrect detection.
reimar
parents:
18885
diff
changeset
|
187 if (stream_eof(demuxer->stream) || strncmp(hdr, "NSVs", 4)) |
054516eecb9b
Better check for non-broken NSVf-header to avoid incorrect detection.
reimar
parents:
18885
diff
changeset
|
188 return 0; |
12175 | 189 } |
190 | |
191 // dummy debug message | |
192 mp_msg(MSGT_DEMUX,MSGL_V,"demux_nsv: Header: %.12s\n",hdr); | |
193 | |
194 // bytes 8-11 audio codec fourcc | |
195 // PCM fourcc needs extra parsing for every audio chunk, yet to implement | |
12896 | 196 if((demuxer->audio->id != -2) && strncmp(hdr+8,"NONE", 4)){//&&strncmp(hdr+8,"VLB ", 4)){ |
31609
cd81fce1f010
Make the stream language an argument to the stream creation function
reimar
parents:
29263
diff
changeset
|
197 sh_audio = new_sh_audio ( demuxer, 0, NULL ); |
26295
c8a489c8cae8
Set demuxer->audio->id to avoid breakage due to r26301
reimar
parents:
25707
diff
changeset
|
198 demuxer->audio->id = 0; |
12175 | 199 demuxer->audio->sh = sh_audio; |
200 sh_audio->format=mmioFOURCC(hdr[8],hdr[9],hdr[10],hdr[11]); | |
201 sh_audio->ds = demuxer->audio; | |
12896 | 202 priv->a_format=mmioFOURCC(hdr[8],hdr[9],hdr[10],hdr[11]); |
12175 | 203 } |
204 | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
205 // store hdr fps |
12175 | 206 priv->fps=hdr[16]; |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
207 |
12896 | 208 if ((demuxer->video->id != -2) && strncmp(hdr+4,"NONE", 4)) { |
12198 | 209 /* Create a new video stream header */ |
210 sh_video = new_sh_video ( demuxer, 0 ); | |
211 | |
212 /* Make sure the demuxer knows about the new video stream header | |
213 * (even though new_sh_video() ought to take care of it) | |
214 */ | |
215 demuxer->video->sh = sh_video; | |
216 | |
217 /* Make sure that the video demuxer stream header knows about its | |
218 * parent video demuxer stream (this is getting wacky), or else | |
219 * video_read_properties() will choke | |
220 */ | |
221 sh_video->ds = demuxer->video; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
222 |
12175 | 223 // bytes 4-7 video codec fourcc |
224 priv->v_format = sh_video->format=mmioFOURCC(hdr[4],hdr[5],hdr[6],hdr[7]); | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
225 |
12175 | 226 // new video stream! parse header |
227 sh_video->disp_w=hdr[12]|(hdr[13]<<8); | |
228 sh_video->disp_h=hdr[14]|(hdr[15]<<8); | |
32105 | 229 sh_video->bih=calloc(1,sizeof(*sh_video->bih)); |
230 sh_video->bih->biSize=sizeof(*sh_video->bih); | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
231 sh_video->bih->biPlanes=1; |
12175 | 232 sh_video->bih->biBitCount=24; |
233 sh_video->bih->biWidth=hdr[12]|(hdr[13]<<8); | |
234 sh_video->bih->biHeight=hdr[14]|(hdr[15]<<8); | |
235 memcpy(&sh_video->bih->biCompression,hdr+4,4); | |
236 sh_video->bih->biSizeImage=sh_video->bih->biWidth*sh_video->bih->biHeight*3; | |
237 | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
238 // here we search for the correct keyframe |
12275 | 239 // vp6 keyframe is when the 2nd byte of the vp6 header is |
240 // 0x36 for VP61 and 0x46 for VP62 | |
12272 | 241 if((priv->v_format==mmioFOURCC('V','P','6','1')) || |
242 (priv->v_format==mmioFOURCC('V','P','6','2')) || | |
243 (priv->v_format==mmioFOURCC('V','P','3','1'))) { | |
244 stream_read(demuxer->stream,buf,10); | |
12277 | 245 if (((((priv->v_format>>16) & 0xff) == '6') && ((buf[8]&0x0e)!=0x06)) || |
12272 | 246 ((((priv->v_format>>16) & 0xff) == '3') && (buf[8]!=0x00 || buf[9]!=0x08))) { |
247 mp_msg(MSGT_DEMUX,MSGL_V,"demux_nsv: searching %.4s keyframe...\n", (char*)&priv->v_format); | |
12277 | 248 while(((((priv->v_format>>16) & 0xff) == '6') && ((buf[8]&0x0e)!=0x06)) || |
12272 | 249 ((((priv->v_format>>16) & 0xff) == '3') && (buf[8]!=0x00 || buf[9]!=0x08))){ |
250 mp_msg(MSGT_DEMUX,MSGL_DBG2,"demux_nsv: %.4s block skip.\n", (char*)&priv->v_format); | |
12179
aeb377ccb110
Fix vp61 keyframe search (do not skip blocks if 1st frame is keyframe)
rtognimp
parents:
12175
diff
changeset
|
251 videolen=(buf[2]>>4)|(buf[3]<<4)|(buf[4]<<0xC); |
aeb377ccb110
Fix vp61 keyframe search (do not skip blocks if 1st frame is keyframe)
rtognimp
parents:
12175
diff
changeset
|
252 audiolen=(buf[5])|(buf[6]<<8); |
12272 | 253 stream_skip(demuxer->stream, videolen+audiolen-3); |
254 stream_read(demuxer->stream,buf,10); | |
12277 | 255 if(stream_eof(demuxer->stream)) return 0; |
12179
aeb377ccb110
Fix vp61 keyframe search (do not skip blocks if 1st frame is keyframe)
rtognimp
parents:
12175
diff
changeset
|
256 if(buf[0]==0x4E){ |
aeb377ccb110
Fix vp61 keyframe search (do not skip blocks if 1st frame is keyframe)
rtognimp
parents:
12175
diff
changeset
|
257 mp_msg(MSGT_DEMUX,MSGL_DBG2,"demux_nsv: Got NSVs block.\n"); |
12272 | 258 stream_skip(demuxer->stream,7); |
259 stream_read(demuxer->stream,buf,10); | |
12175 | 260 } |
261 } | |
262 } | |
263 | |
13299
6f8fe531dd73
avoid always skipping first junk with a "sync lost" message
reimar
parents:
12896
diff
changeset
|
264 // data starts 10 bytes before current pos but later |
6f8fe531dd73
avoid always skipping first junk with a "sync lost" message
reimar
parents:
12896
diff
changeset
|
265 // we seek 17 backwards |
6f8fe531dd73
avoid always skipping first junk with a "sync lost" message
reimar
parents:
12896
diff
changeset
|
266 stream_skip(demuxer->stream,7); |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
267 } |
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
268 |
12175 | 269 switch(priv->fps){ |
270 case 0x80: | |
271 sh_video->fps=30; | |
272 break; | |
273 case 0x81: | |
274 sh_video->fps=(float)30000.0/1001.0; | |
275 break; | |
276 case 0x82: | |
277 sh_video->fps=25; | |
278 break; | |
279 case 0x83: | |
280 sh_video->fps=(float)24000.0/1001.0; | |
281 break; | |
282 case 0x85: | |
283 sh_video->fps=(float)15000.0/1001.0; | |
284 break; | |
15991 | 285 case 0x89: |
286 sh_video->fps=(float)10000.0/1001.0; | |
287 break; | |
12175 | 288 default: |
289 sh_video->fps = (float)priv->fps; | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
290 } |
12175 | 291 sh_video->frametime = (float)1.0 / (float)sh_video->fps; |
12198 | 292 } |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
293 } |
12175 | 294 |
13299
6f8fe531dd73
avoid always skipping first junk with a "sync lost" message
reimar
parents:
12896
diff
changeset
|
295 // seek to start of NSV header |
6f8fe531dd73
avoid always skipping first junk with a "sync lost" message
reimar
parents:
12896
diff
changeset
|
296 stream_seek(demuxer->stream,stream_tell(demuxer->stream)-17); |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
297 |
12175 | 298 return demuxer; |
299 } | |
300 | |
16175 | 301 static int nsv_check_file ( demuxer_t* demuxer ) |
12175 | 302 { |
20473 | 303 uint32_t hdr = 0; |
16318 | 304 int i; |
12175 | 305 |
306 mp_msg ( MSGT_DEMUX, MSGL_V, "Checking for Nullsoft Streaming Video\n" ); | |
29263
0f1b5b68af32
whitespace cosmetics: Remove all trailing whitespace.
diego
parents:
29238
diff
changeset
|
307 |
16318 | 308 for (i = 0; i < HEADER_SEARCH_SIZE; i++) { |
20473 | 309 uint8_t c = stream_read_char(demuxer->stream); |
310 if (stream_eof(demuxer->stream)) | |
16318 | 311 return 0; |
20473 | 312 if (hdr == mmioFOURCC('s', 'V', 'S', 'N') || |
313 (hdr == mmioFOURCC('f', 'V', 'S', 'N') && !c)) { | |
314 stream_seek(demuxer->stream,stream_tell(demuxer->stream)-5); | |
16318 | 315 return DEMUXER_TYPE_NSV; |
316 } | |
20473 | 317 hdr = (hdr << 8) | c; |
16318 | 318 } |
319 | |
320 return 0; | |
12175 | 321 } |
322 | |
16175 | 323 static void demux_close_nsv(demuxer_t* demuxer) { |
12175 | 324 nsv_priv_t* priv = demuxer->priv; |
325 | |
326 free(priv); | |
327 | |
328 } | |
16175 | 329 |
330 | |
25707
d4fe6e23283e
Make all demuxer_desc_t const, thus moving them to .rodata
reimar
parents:
22605
diff
changeset
|
331 const demuxer_desc_t demuxer_desc_nsv = { |
16175 | 332 "NullsoftVideo demuxer", |
333 "nsv", | |
334 "Nullsoft Streaming Video", | |
335 "Reza Jelveh", | |
336 "nsv and nsa streaming files", | |
337 DEMUXER_TYPE_NSV, | |
16318 | 338 0, // safe but expensive autodetect |
16175 | 339 nsv_check_file, |
340 demux_nsv_fill_buffer, | |
341 demux_open_nsv, | |
342 demux_close_nsv, | |
343 demux_seek_nsv, | |
344 NULL | |
345 }; |