Mercurial > mplayer.hg
annotate libmpdemux/mp3_hdr.h @ 24086:f5b32d12b691
remove gconvert_uri_to_filename() and use url_unescape_string() instead.
reasons:
* gconvert strdup()s the original string, but it may exit without returning or freeing it.
* gconvert returns the original pointer when no % escaping is done. It is then free()ed and used in that state.
* gconvert doesn't consider that % may be at the end of the string and could continue parsing past the end.
* gconvert would try to free() pointer that iconv() have modified.
* gconvert would try to convert filenames from utf-8 to iso8859-1.
Seems like no other DnD programs convert to utf-8 and/or honors CHARSET.
Not converting seems to work best. Fix it if problem arises.
author | iive |
---|---|
date | Mon, 20 Aug 2007 14:17:43 +0000 |
parents | b5c2254d13f8 |
children | 6ac1ece1f9fe |
rev | line source |
---|---|
4710 | 1 |
16162
b5c2254d13f8
set i_bps in demux_audio for WAV and MP3 to avoid division by zero before
reimar
parents:
15199
diff
changeset
|
2 int mp_get_mp3_header(unsigned char* hbuf,int* chans, int* freq, int* spf, int* mpa_layer, int* br); |
6763 | 3 |
16162
b5c2254d13f8
set i_bps in demux_audio for WAV and MP3 to avoid division by zero before
reimar
parents:
15199
diff
changeset
|
4 #define mp_decode_mp3_header(hbuf) mp_get_mp3_header(hbuf,NULL,NULL,NULL,NULL,NULL) |
4710 | 5 |
6 static inline int mp_check_mp3_header(unsigned int head){ | |
7 if( (head & 0x0000e0ff) != 0x0000e0ff || | |
8 (head & 0x00fc0000) == 0x00fc0000) return 0; | |
9 if(mp_decode_mp3_header((unsigned char*)(&head))<=0) return 0; | |
10 return 1; | |
11 } |