Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | MusicChunk: rename struct to MusicChunk | Max Kellermann | 2014-08-12 | 4 | -6/+7 |
| | |||||
* | decoder/Mp4v2: fix crash with undefined error | Andrée Ekroth | 2014-08-08 | 1 | -6/+4 |
| | | | | | | | | | When no track is found the error is now properly set. Previously the calling function tried to log an undefined error, which resulted in a crash. MPD falls back to ffmpeg for unsupported tracks, such as ALAC. This should fix issue 4051. | ||||
* | decoder/Mp4v2: add MP4v2 decoder plugin | Andrée Ekroth | 2014-08-07 | 3 | -0/+355 |
| | | | | | This plugin uses the MP4v2 library to play mp4/m4a files. It is limited to file_decode. | ||||
* | decoder/dsdiff: move artist/title/id3 offsets out of DsdiffMetaData | Max Kellermann | 2014-07-12 | 1 | -22/+14 |
| | | | | They are only used inside dsdiff_read_metadata_extra(). | ||||
* | Merge branch 'v0.18.x' | Max Kellermann | 2014-07-12 | 1 | -12/+9 |
|\ | |||||
| * | decoder/dsdiff: simplify dsdlib_skip() call | Max Kellermann | 2014-07-12 | 1 | -4/+3 |
| | | |||||
| * | decoder/dsdiff: simplify loop condition, merge branches | Max Kellermann | 2014-07-12 | 1 | -7/+2 |
| | | |||||
| * | decoder/dsdiff: ignore garbage null byte at end of file | Max Kellermann | 2014-07-12 | 1 | -1/+1 |
| | | | | | | | | | | Failure to read another chunk header is not fatal. Continue to read metadata. | ||||
| * | decoder/dsdiff: fix metadata parser bug (uninitialized variables) | Max Kellermann | 2014-07-12 | 1 | -1/+4 |
| | | |||||
* | | DecoderBuffer: implement _skip() using decoder_skip() | Max Kellermann | 2014-07-12 | 1 | -17/+8 |
| | | |||||
* | | DecoderBuffer: add method _need() | Max Kellermann | 2014-07-12 | 3 | -31/+42 |
| | | | | | | | | Move code from the FAAD decoder plugin. | ||||
* | | DecoderBuffer: remove unused method _is_full() | Max Kellermann | 2014-07-12 | 2 | -10/+0 |
| | | |||||
* | | decoder/faad: eliminate the adts_find_frame() loop | Max Kellermann | 2014-07-12 | 1 | -5/+2 |
| | | | | | | | | | | This loop is completely unnecessary. We just need to find the first ADTS frame and feed it into NeAACDecInit(). | ||||
* | | decoder/faad: split faad_stream_decode() | Max Kellermann | 2014-07-12 | 1 | -10/+16 |
| | | | | | | | | Eliminate duplicate cleanup code. | ||||
* | | DecoderBuffer: remove unused method _is_empty() | Max Kellermann | 2014-07-12 | 2 | -10/+0 |
| | | |||||
* | | Merge branch 'v0.18.x' | Max Kellermann | 2014-07-12 | 3 | -54/+99 |
|\| | |||||
| * | decoder/faad: estimate song duration for remote files | Max Kellermann | 2014-07-12 | 1 | -0/+22 |
| | | | | | | | | | | | | | | | | Previously, MPD tried to slurp the whole song file, count the number of frames and calculate the song duration from that. That however is extremely expensive for remote files, and will delay playback for a long time. Workaround: check only the first 128 frames and try to extrapolate from here. Fixes Mantis ticket 0004035. | ||||
| * | decoder/faad: bail out early if sample rate is invalid | Max Kellermann | 2014-07-12 | 1 | -0/+2 |
| | | |||||
| * | decoder/faad: use adts_check_frame() in faad_song_duration() | Max Kellermann | 2014-07-12 | 1 | -2/+1 |
| | | | | | | | | Eliminate more duplicate code. | ||||
| * | decoder/faad: test "seekable" after ADTS frame check | Max Kellermann | 2014-07-12 | 1 | -1/+5 |
| | | | | | | | | | | Don't bother to check for ADIF just because the stream is not seekable. | ||||
| * | decoder/faad: move code to faad_decoder_new() | Max Kellermann | 2014-07-12 | 1 | -14/+17 |
| | | | | | | | | Merge some duplicate code. | ||||
| * | decoder/faad: remove unnecessary read | Max Kellermann | 2014-07-12 | 1 | -2/+0 |
| | | | | | | | | Eliminate some overhead when the caller doesn't need the buffer. | ||||
| * | DecoderBuffer: add method _clear() | Max Kellermann | 2014-07-12 | 1 | -8/+3 |
| | | |||||
| * | decoder/faad: check sample_rate, not frames_per_second | Max Kellermann | 2014-07-11 | 1 | -2/+4 |
| | | | | | | | | Checking the integer is faster, easier and more reliable. | ||||
| * | decoder/faad: make variables more local | Max Kellermann | 2014-07-11 | 1 | -71/+49 |
| | | |||||
| * | decoder/faad: use MAX_CHANNELS | Max Kellermann | 2014-07-11 | 1 | -4/+2 |
| | | | | | | | | .. instead of declaring a new constant. | ||||
* | | decoder/sndfile: implement scan_stream() instead of scan_file() | Max Kellermann | 2014-07-11 | 1 | -5/+6 |
| | | |||||
* | | decoder/sndfile: make variables more local | Max Kellermann | 2014-07-11 | 1 | -10/+7 |
| | | |||||
* | | decoder/sndfile: support more tag types | Max Kellermann | 2014-07-11 | 1 | -0/+4 |
| | | |||||
* | | decoder/sndfile: add str_type to TagType table | Max Kellermann | 2014-07-11 | 1 | -3/+11 |
| | | |||||
* | | decoder/sndfile: move code to sndfile_handle_tag() | Max Kellermann | 2014-07-11 | 1 | -15/+12 |
| | | |||||
* | | decoder/sndfile: log libsndfile version on startup | Max Kellermann | 2014-07-11 | 1 | -1/+8 |
| | | |||||
* | | Merge branch 'v0.18.x' | Max Kellermann | 2014-07-11 | 2 | -30/+31 |
|\| | |||||
| * | decoder/sndfile: use decoder_read_full() | Max Kellermann | 2014-07-11 | 1 | -16/+6 |
| | | | | | | | | | | Replaces the loop in sndfile_vio_read(), eliminating duplicate and fragile code. | ||||
| * | decoder/sndfile: use decoder_read() | Max Kellermann | 2014-07-11 | 1 | -16/+22 |
| | | | | | | | | .. instead of InputStream::LockRead(). The former is cancellable. | ||||
| * | decoder/sndfile: log seek errors | Max Kellermann | 2014-07-11 | 1 | -1/+4 |
| | | |||||
| * | decoder/audiofile: log seek errors | Max Kellermann | 2014-07-11 | 1 | -0/+1 |
| | | |||||
| * | decoder/audiofile: fix typo in comment | Max Kellermann | 2014-07-11 | 1 | -1/+1 |
| | | |||||
* | | decoder/audiofile: log libaudiofile errors | Max Kellermann | 2014-07-10 | 1 | -4/+15 |
| | | |||||
* | | decoder/audiofile: make variables more local | Max Kellermann | 2014-07-10 | 1 | -28/+24 |
| | | |||||
* | | decoder/audiofile: implement scan_stream() instead of scan_file() | Max Kellermann | 2014-07-10 | 1 | -23/+23 |
| | | |||||
* | | decoder/audiofile: use audiofile_get_duration() in _stream_decode() | Max Kellermann | 2014-07-10 | 1 | -5/+2 |
| | | |||||
* | | decoder/audiofile: split audiofile_get_duration() | Max Kellermann | 2014-07-10 | 1 | -4/+11 |
| | | |||||
* | | decoder/audiofile: remove unused Error variable | Max Kellermann | 2014-07-09 | 1 | -1/+0 |
| | | |||||
* | | Merge branch 'v0.18.x' | Max Kellermann | 2014-07-09 | 6 | -46/+49 |
|\| | |||||
| * | decoder/dsd: use decoder_read_full() where appropriate | Joff | 2014-07-09 | 4 | -31/+19 |
| | | | | | | | | | | | | | | Addresses Mantis ticket 0004015. [mk: use decoder_read_full() only when needed, and a few formal changes] | ||||
| * | decoder/audiofile: use decoder_read_full() | Max Kellermann | 2014-07-09 | 1 | -1/+6 |
| | | | | | | | | | | Works around WAV stream playback bug, because libaudiofile does not like partial reads (Mantis 0004028). | ||||
| * | DecoderAPI: add function decoder_read_full() | Max Kellermann | 2014-07-09 | 1 | -12/+2 |
| | | | | | | | | Move code from the "mad" plugin. | ||||
| * | DecoderAPI: add function decoder_skip() | Max Kellermann | 2014-07-09 | 1 | -14/+1 |
| | | | | | | | | Move code from the "mad" plugin. | ||||
| * | decoder/audiofile: use decoder_read() | Max Kellermann | 2014-07-09 | 1 | -15/+24 |
| | | | | | | | | | | .. instead of InputStream::LockRead(). The former is cancellable. |