Commit message (Collapse) | Author | Files | Lines | ||
---|---|---|---|---|---|
2014-11-07 | input/AsyncInputStream: set Error when seeking unseekable | Max Kellermann | 1 | -1/+4 | |
Fixes crash in the "audiofile" decoder while logging the seek error. | |||||
2014-11-07 | input/Open: expose input_domain | Max Kellermann | 3 | -2/+52 | |
2014-11-02 | input/curl: forget Content-Length (and more) after redirect | Max Kellermann | 1 | -0/+26 | |
Fixes playback of redirected streams. | |||||
2014-11-02 | AsyncInputStream: add method ClearTag() | Max Kellermann | 1 | -0/+4 | |
2014-11-02 | InputStream: add method ClearMimeType() | Max Kellermann | 1 | -0/+4 | |
2014-11-02 | input/curl: fix curl_easy_setopt() parameter types | Max Kellermann | 1 | -4/+4 | |
2014-11-02 | Decoder, Playlist: ignore URI query string for plugin detection | Max Kellermann | 2 | -6/+8 | |
Use the new uri_get_suffix() overload that removes the query string. | |||||
2014-11-02 | util/UriUtil: add uri_get_suffix() overload that ignores query string | Max Kellermann | 2 | -0/+28 | |
2014-11-02 | PlaylistFile: don't allow empty playlist name | Max Kellermann | 1 | -0/+4 | |
2014-11-02 | playlist/m3u: recognize the file suffix ".m3u8" | Max Kellermann | 2 | -1/+3 | |
2014-11-02 | decoder/faad: remove workaround for ancient libfaad2 ABI bug | Max Kellermann | 1 | -10/+2 | |
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! | |||||
2014-11-02 | decoder/ffmpeg: recognize MIME type audio/aacp | Steven OBrien | 1 | -0/+1 | |
2014-11-02 | output/roar: remove unnecessary "volatile" keyword | Max Kellermann | 1 | -1/+1 | |
A mutex acts as a memory barrier, and thus "volatile" is not necessary. | |||||
2014-11-02 | TagString: use g_strndup() for unterminated string | Max Kellermann | 1 | -1/+1 | |
Fixes buffer overflow bug. | |||||
2014-11-02 | lib/upnp/Discovery: add missing stdlib.h include | Max Kellermann | 1 | -0/+1 | |
2014-11-01 | input/curl: fix curl_easy_setopt() parameter types | Max Kellermann | 1 | -3/+3 | |
2014-11-01 | Decoder, Playlist: ignore URI query string for plugin detection | Max Kellermann | 3 | -5/+10 | |
Use the new uri_get_suffix() overload that removes the query string. | |||||
2014-11-01 | util/UriUtil: add uri_get_suffix() overload that ignores query string | Max Kellermann | 2 | -0/+28 | |
2014-10-31 | Main: run the OS X native event loop after forking | NanoTech | 1 | -0/+27 | |
2014-10-31 | Revert "Main: run the OS X native event loop" | NanoTech | 3 | -50/+0 | |
This reverts commit f0be48ff90503d9ffa5b295fd4454eec753950ee (except for the NEWS entry). If libdispatch (GCD) is used before forking, it can't safely be used again after forking. | |||||
2014-10-31 | PlaylistFile: don't allow empty playlist name | Max Kellermann | 1 | -0/+4 | |
2014-10-28 | decoder/mad: fix negative replay gain values | Max Kellermann | 1 | -1/+1 | |
Negating an unsigned integer does not work. | |||||
2014-10-28 | TextInputStream: don't ignore unterminated last line | Max Kellermann | 1 | -4/+16 | |
2014-10-26 | playlist/m3u: recognize the file suffix ".m3u8" | Max Kellermann | 2 | -0/+2 | |
2014-10-25 | OutputThread: fall back to PCM if given DSD sample rate is not supported | Max Kellermann | 1 | -0/+30 | |
Works around the "PCM conversion from f to dsd is not implemented" error message that prevents DSD playback. | |||||
2014-10-25 | decoder/faad: remove workaround for ancient libfaad2 ABI bug | Max Kellermann | 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! | |||||
2014-10-25 | decoder/ffmpeg: recognize MIME type audio/aacp | Steven OBrien | 1 | -0/+1 | |
2014-10-25 | fs/Charset: work around clang's -Wunused-const-variable | Max Kellermann | 1 | -1/+2 | |
MPD_PATH_MAX_UTF8 is only used by GLib-specific code currently. | |||||
2014-10-24 | OutputThread: close the output plugin after filter failure | Max Kellermann | 1 | -0/+1 | |
Fixes memory leak because ao_plugin_close() never gets called. | |||||
2014-10-24 | OutputThread: unlock mutex for CloseFilter() | Max Kellermann | 2 | -0/+14 | |
Be consistent. | |||||
2014-10-23 | output/roar: remove unnecessary "volatile" keyword | Max Kellermann | 1 | -1/+1 | |
A mutex acts as a memory barrier, and thus "volatile" is not necessary. | |||||
2014-10-23 | pcm/ChannelsConverter: fix variable used to generate error message | Max Kellermann | 1 | -1/+1 | |
Use the "_format" parameter instead of the (uninitialized) "format" attribute. | |||||
2014-10-23 | pcm/FormatConverter: move check to Open() | Max Kellermann | 1 | -10/+24 | |
Report unsupported format while opening the filter, not later when the first conversion takes place. | |||||
2014-10-23 | pcm/PcmConvert: assign {src,dest}_format at the end | Max Kellermann | 1 | -12/+13 | |
Fixes assertion failure in destructor by not assigning {src,dest}_format when an error occurs. | |||||
2014-10-23 | pcm/PcmConvert: make AudioFormat parameters "const" | Max Kellermann | 1 | -1/+1 | |
2014-10-19 | TextInputStream: manually shift the buffer before reading | Max Kellermann | 1 | -0/+2 | |
Fixes truncated lines in m3u and cue files (regression by commit 67958f7). | |||||
2014-10-19 | util/StaticFifoBuffer: make Shift() public | Max Kellermann | 1 | -2/+0 | |
2014-10-17 | playlist/extm3u: strip first line for #EXTM3U detection | Max Kellermann | 1 | -2/+6 | |
2014-10-11 | ThreadInputStream: call ThreadRead() inside the thread instead of Read() | Max Kellermann | 1 | -1/+1 | |
Fixes deadlock bug in the "mms" plugin. | |||||
2014-10-11 | ThreadInputStream: add assertions | Max Kellermann | 1 | -0/+8 | |
2014-10-11 | util/DynamicFifoBuffer: make the "Range" type public | Max Kellermann | 1 | -0/+1 | |
Export it from the protected base class. This fixes a build failure on Mac OS X. | |||||
2014-10-10 | db/upnp/Util: move caturl() to util/UriUtil.cxx | Max Kellermann | 6 | -32/+39 | |
2014-10-10 | event/IdleMonitor: remove redundant comment | Max Kellermann | 1 | -2/+1 | |
2014-10-10 | ZeroconfBonjour: use htons() instead of g_htons() | Max Kellermann | 1 | -3/+3 | |
2014-10-10 | TagString: implement fix_utf8() without GLib | Max Kellermann | 1 | -22/+34 | |
2014-10-10 | util/UTF8: add SequenceLengthUTF8() | Max Kellermann | 2 | -0/+96 | |
2014-10-10 | util/UTF8: new library | Max Kellermann | 2 | -0/+339 | |
2014-10-10 | TagString: return WritableBuffer<char> | Max Kellermann | 3 | -24/+26 | |
2014-10-10 | TagString: use strndup() for unterminated string | Max Kellermann | 1 | -1/+1 | |
Fixes buffer overflow bug. | |||||
2014-10-10 | TagString: remove ISO-Latin-1 fallback | Max Kellermann | 1 | -14/+1 | |
MPD handles all strings in UTF-8 internally. Those decoders which read Latin-1 tags are supposed to implement the conversion, instead of passing Latin-1 to TagBuilder::AddItem(). FixTagString() is simply the wrong place to do that, and hard-coding Latin-1 is kind of arbitrary. |