Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
* | | | util/SplitString: rename to DivideString | Max Kellermann | 2014-12-03 | 2 | -4/+4 | |
| | | | ||||||
* | | | decoder/gme: simplify ParseContainerPath() | Max Kellermann | 2014-12-02 | 1 | -32/+27 | |
| | | | | | | | | | | | | | | | Use simple string and path parsing functions instead of GLib's g_pattern_match(), which was used in a very clumsy way. | |||||
* | | | decoder/gme: merge get_container_name() and get_song_num() | Max Kellermann | 2014-12-02 | 1 | -54/+28 | |
| | | | | | | | | | | | | There is duplicate code in the two. | |||||
* | | | decoder/gme: get_song_num() returns unsigned | Max Kellermann | 2014-12-01 | 1 | -6/+9 | |
| | | | ||||||
* | | | decoder/gme: move code to ScanMusicEmu() | Max Kellermann | 2014-12-01 | 1 | -14/+22 | |
| | | | ||||||
* | | | decoder/gme: move code to ScanGmeInfo() | Max Kellermann | 2014-12-01 | 1 | -34/+42 | |
| | | | ||||||
* | | | Merge tag 'v0.19.5' | Max Kellermann | 2014-11-26 | 3 | -359/+0 | |
|\| | | ||||||
| * | | decoder/mp4v2: remove because of incompatible license | Max Kellermann | 2014-11-25 | 3 | -359/+0 | |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | libmp4v2 is licensed under MPL 1.1, which is incompatible with GPLv2. Unfortunately, this means that we must remove the plugin. More information can be found in the Debian bug report: http://bugs.debian.org/767504 | |||||
* | | | Merge branch 'v0.19.x' | Max Kellermann | 2014-11-24 | 2 | -3/+3 | |
|\| | | ||||||
| * | | decoder/{dsdiff,dsf,opus}: fix deadlock while seeking | Max Kellermann | 2014-11-24 | 2 | -3/+3 | |
| | | | ||||||
* | | | configure.ac: add macro MPD_ENABLE_AUTO_PKG_LIB | Max Kellermann | 2014-11-22 | 5 | -17/+17 | |
| | | | ||||||
* | | | configure.ac: add macro MPD_ENABLE_AUTO_PKG | Max Kellermann | 2014-11-21 | 1 | -10/+8 | |
| | | | | | | | | | | | | Simplify the definition of many build options. | |||||
* | | | Merge tag 'v0.19.4' | Max Kellermann | 2014-11-18 | 1 | -0/+7 | |
|\| | | ||||||
| * | | decoder/opus: add MIME types audio/ogg and application/ogg | Max Kellermann | 2014-11-12 | 1 | -0/+7 | |
| | | | ||||||
* | | | Merge tag 'v0.19.3' | Max Kellermann | 2014-11-11 | 2 | -19/+68 | |
|\| | | ||||||
| * | | decoder/opus: support chained streams | Max Kellermann | 2014-11-11 | 1 | -1/+36 | |
| | | | ||||||
| * | | decoder/opus: move code to HandleEOS() | Max Kellermann | 2014-11-11 | 1 | -1/+8 | |
| | | | ||||||
| * | | decoder/opus: improved error logging | Max Kellermann | 2014-11-11 | 1 | -4/+11 | |
| | | | ||||||
| * | | decoder/opus: fix mistyped LoadEOSPacket() return value | Max Kellermann | 2014-11-11 | 1 | -1/+1 | |
| | | | ||||||
| * | | decoder/opus: eliminate flag "found_opus" | Max Kellermann | 2014-11-11 | 1 | -5/+3 | |
| | | | | | | | | | | | | Check opus_decoder!=nullptr instead. | |||||
| * | | decoder/opus: add constexpr output_buffer_frames | Max Kellermann | 2014-11-11 | 1 | -8/+10 | |
| | | | ||||||
| * | | decoder/audiofile: fix bit rate calculation | Max Kellermann | 2014-11-10 | 1 | -1/+1 | |
| | | | ||||||
* | | | Merge branch 'v0.19.x' | Max Kellermann | 2014-11-07 | 1 | -1/+2 | |
|\| | | ||||||
| * | | decoder/ffmpeg: support opus | Max Kellermann | 2014-11-07 | 1 | -1/+2 | |
| | | | ||||||
* | | | Merge tag 'v0.19.2' | Max Kellermann | 2014-11-02 | 4 | -22/+7 | |
|\| | | ||||||
| * | | Decoder, Playlist: ignore URI query string for plugin detection | Max Kellermann | 2014-11-01 | 1 | -1/+2 | |
| | | | | | | | | | | | | Use the new uri_get_suffix() overload that removes the query string. | |||||
| * | | decoder/mad: fix negative replay gain values | Max Kellermann | 2014-10-28 | 1 | -1/+1 | |
| | | | | | | | | | | | | Negating an unsigned integer does not work. | |||||
| * | | decoder/faad: remove workaround for ancient libfaad2 ABI bug | Max Kellermann | 2014-10-25 | 2 | -20/+4 | |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Many years ago, FAAD had a serious ABI bug: the NeAACDecInit() prototype in its header declared the "samplerate" parameter to be "unsigned long *", but internally, the function assumed it was "uint32_t *" instead. On 32 bit machines, that was no difference, but on 64 bit, this left one portion of the return value uninitialized; and worse, on big-endian, the wrong word was filled. This bug had to be worked around in MPD (commit 9c4e97a6). A few months later, the bug was fixed in the FAAD CVS in commit 1.117 on file libfaad/decoder.c; the commit message was: "Use public headers internally to prevent duplicate declarations" The commit message was too brief at best; the problem was not duplicate declarations, but a prototype mismatch. No mention of the bug fix in the ChangeLog. The MPD project never learned about this bug fix, and so MPD would always pass a "uin32_t *" dressed up as a "unsigned long *". Nearly 6 years later, it's about time to fix this second ABI problem. Let's kill the workaround! | |||||
* | | | decoder/wavpack: don't use GLib | Max Kellermann | 2014-10-25 | 1 | -3/+3 | |
|/ / | ||||||
* | | decoder/ffmpeg: recognize MIME type audio/aacp | Steven OBrien | 2014-10-25 | 1 | -0/+1 | |
| | | ||||||
* | | input/Open: use OpenLocalInputStream() | Max Kellermann | 2014-10-02 | 1 | -3/+1 | |
| | | | | | | | | | | | | | | Make the "open" method of plugins "file" and "archive" dummy methods that always fail. Instead, let InputStream::Open() hard-code access to these two plugins by using OpenLocalInputStream(). This allows simplifyin the algorithm for falling back to probing archive plugins. | |||||
* | | DecoderThread: use OpenLocalInputStream() for local files | Max Kellermann | 2014-10-02 | 1 | -1/+20 | |
| | | ||||||
* | | Merge tag 'v0.18.16' | Max Kellermann | 2014-09-26 | 1 | -0/+2 | |
|\| | ||||||
* | | decoder/mp4v2: add tag table | Max Kellermann | 2014-09-24 | 1 | -10/+19 | |
| | | ||||||
* | | decoder/mpg123: support ID3v2, ReplayGain and MixRamp | Max Kellermann | 2014-09-24 | 1 | -1/+90 | |
| | | ||||||
* | | decoder/mpg123: make variables more local | Max Kellermann | 2014-09-24 | 1 | -20/+11 | |
| | | ||||||
* | | decoder/flac: pass VorbisComment to flac_parse_mixramp() | Max Kellermann | 2014-09-24 | 3 | -6/+4 | |
| | | ||||||
* | | decoder/flac: move code to tag/MixRamp.cxx | Max Kellermann | 2014-09-24 | 1 | -35/+10 | |
| | | ||||||
* | | decoder/mad: move code to tag/MixRamp.cxx | Max Kellermann | 2014-09-24 | 1 | -5/+2 | |
| | | ||||||
* | | decoder/flac: pass VorbisComment to flac_parse_replay_gain() | Max Kellermann | 2014-09-24 | 3 | -6/+3 | |
| | | ||||||
* | | tag/ReplayGain: add VorbisComment parser | Max Kellermann | 2014-09-24 | 2 | -41/+12 | |
| | | | | | | | | Move code from the Vorbis and FLAC decoder plugins. | |||||
* | | decoder/{vorbis,flac}: move duplicate code to tag/VorbisComment.cxx | Max Kellermann | 2014-09-24 | 2 | -24/+3 | |
| | | ||||||
* | | tag/ApeReplayGain, decoder/mad: move duplicate code to tag/ReplayGain.cxx | Max Kellermann | 2014-09-24 | 1 | -12/+2 | |
| | | ||||||
* | | DecoderBuffer: struct to class | Max Kellermann | 2014-09-22 | 1 | -1/+2 | |
| | | ||||||
* | | DecoderBuffer: convert functions to methods | Max Kellermann | 2014-09-22 | 3 | -121/+85 | |
| | | ||||||
* | | decoder/faad: use DecoderBuffer references | Max Kellermann | 2014-09-22 | 1 | -27/+27 | |
| | | ||||||
* | | decoder/faad: allocate DecoderBuffer on stack | Max Kellermann | 2014-09-22 | 1 | -13/+8 | |
| | | ||||||
* | | DecoderBuffer: export the struct | Max Kellermann | 2014-09-22 | 3 | -58/+28 | |
| | | | | | | | | Eliminates the functions _new() and _free(). | |||||
* | | DecoderBuffer: make "decoder" const | Max Kellermann | 2014-09-21 | 1 | -1/+1 | |
| | | ||||||
* | | DecoderBuffer: convert pointer to reference | Max Kellermann | 2014-09-21 | 1 | -5/+5 | |
| | |