aboutsummaryrefslogtreecommitdiffstats
path: root/src (follow)
Commit message (Collapse)AuthorAgeFilesLines
...
| * | decoder/opus: eliminate flag "found_opus"Max Kellermann2014-11-111-5/+3
| | | | | | | | | | | | Check opus_decoder!=nullptr instead.
| * | decoder/opus: add constexpr output_buffer_framesMax Kellermann2014-11-111-8/+10
| | |
| * | Main: fix compilation on OS X using non-Apple compilersMisty De Meo2014-11-111-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Commit d42c0f1dc5063d50a62817b63a1c2a4507c46071 added an OS X-specific method of calling mpd_main_after_fork(), which uses Grand Central Dispatch. Since this uses a block literal, it breaks compilation on compilers which don't support the block extension, e.g. non-Apple compilers. This affects users on older OS X releases with GCD (which depend on older Clang releases, or Apple GCCs, which don't support the C++11 features MPD needs); or which don't support GCD at all (10.5 and lower). This patch changes the #ifdef so that the non-GCD code is used as it was on OS X before this patch if blocks aren't available, via checking __BLOCKS__ macro.
| * | pcm/SoxrResampler: round output buffer size upMax Kellermann2014-11-101-1/+2
| | | | | | | | | | | | | | | | | | | | | | | | The old formula calculates the output buffer size with "regular" rounding (to the nearest integer), however sometimes, that is insufficient and the last sample cannot be resampled. This causes audible distortions. By changing the formula to consider the worst case (always round up), this problem is eliminated.
| * | decoder/audiofile: fix bit rate calculationMax Kellermann2014-11-101-1/+1
| | |
| * | input/curl: ignore ResponseBoundary() while seekingMax Kellermann2014-11-101-0/+4
| | | | | | | | | | | | | | | | | | While seeking, metadata must not be updated. ResponseBoundary() was added in MPD 0.19.1, but I forgot to add the IsSeeking() check there. This caused the "seekable" flag to reset.
| * | tag/Set: do AlbumArtist/Artist fallback only if AlbumArtist is not disabledMax Kellermann2014-11-081-0/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | On "list albumartist", songs that have no AlbumArtist tag will use the Artist tag. However, if AlbumArtist is disabled via "metadata_to_use", the TagBuilder::AddItem() call is ignored, and PrintUniqueTag() attempts to print a nullptr string. This commit fixes the problem by attempting the fallback only if AlbumArtist is not disabled.
| * | db/Count: include cleanupMax Kellermann2014-11-081-1/+1
| | |
* | | db/upnp/Directory: TitleToPathSegment() returns rvalue referenceMax Kellermann2014-11-091-2/+2
| | | | | | | | | | | | Eliminate one implicit std::string copy.
* | | db/upnp/Directory: apply coding styleMax Kellermann2014-11-091-23/+23
| | |
* | | db/upnp/Directory: move checkobjok() to class UPnPDirObjectMax Kellermann2014-11-082-11/+9
| | |
* | | db/upnp/Object: apply coding styleMax Kellermann2014-11-083-21/+28
| | |
* | | Merge branch 'v0.19.x'Max Kellermann2014-11-077-5/+60
|\| |
| * | decoder/ffmpeg: support opusMax Kellermann2014-11-071-1/+2
| | |
| * | db/upnp: fix valgrind warningMax Kellermann2014-11-071-0/+1
| | |
| * | lib/upnp/ContentDirectoryService: swap uri_apply_base() parametersMax Kellermann2014-11-071-1/+1
| | | | | | | | | | | | | | | | | | When uri_apply_base() was moved from db/upnp/Util.cpp to util/UriUtil.cpp, the parameter order was changed, however without swapping the parameters in the ContentDirectoryService constructor.
| * | input/AsyncInputStream: set Error when seeking unseekableMax Kellermann2014-11-071-1/+4
| | | | | | | | | | | | Fixes crash in the "audiofile" decoder while logging the seek error.
| * | input/Open: expose input_domainMax Kellermann2014-11-073-2/+52
| | |
* | | Merge tag 'v0.19.2'Max Kellermann2014-11-0220-84/+161
|\| |
| * | input/curl: forget Content-Length (and more) after redirectMax Kellermann2014-11-021-0/+26
| | | | | | | | | | | | Fixes playback of redirected streams.
| * | AsyncInputStream: add method ClearTag()Max Kellermann2014-11-021-0/+4
| | |
| * | InputStream: add method ClearMimeType()Max Kellermann2014-11-021-0/+4
| | |
| * | Merge branch 'v0.18.x' into v0.19.xMax Kellermann2014-11-021-1/+1
| |\|
| | * input/curl: fix curl_easy_setopt() parameter typesMax Kellermann2014-11-021-4/+4
| | |
| | * Decoder, Playlist: ignore URI query string for plugin detectionMax Kellermann2014-11-022-6/+8
| | | | | | | | | | | | Use the new uri_get_suffix() overload that removes the query string.
| | * util/UriUtil: add uri_get_suffix() overload that ignores query stringMax Kellermann2014-11-022-0/+28
| | |
| | * PlaylistFile: don't allow empty playlist nameMax Kellermann2014-11-021-0/+4
| | |
| | * playlist/m3u: recognize the file suffix ".m3u8"Max Kellermann2014-11-022-1/+3
| | |
| | * decoder/faad: remove workaround for ancient libfaad2 ABI bugMax Kellermann2014-11-021-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!
| | * decoder/ffmpeg: recognize MIME type audio/aacpSteven OBrien2014-11-021-0/+1
| | |
| | * output/roar: remove unnecessary "volatile" keywordMax Kellermann2014-11-021-1/+1
| | | | | | | | | | | | | | | A mutex acts as a memory barrier, and thus "volatile" is not necessary.
| | * TagString: use g_strndup() for unterminated stringMax Kellermann2014-11-021-1/+1
| | | | | | | | | | | | Fixes buffer overflow bug.
| * | lib/upnp/Discovery: add missing stdlib.h includeMax Kellermann2014-11-021-0/+1
| | |
| * | input/curl: fix curl_easy_setopt() parameter typesMax Kellermann2014-11-011-3/+3
| | |
| * | Decoder, Playlist: ignore URI query string for plugin detectionMax Kellermann2014-11-013-5/+10
| | | | | | | | | | | | Use the new uri_get_suffix() overload that removes the query string.
| * | util/UriUtil: add uri_get_suffix() overload that ignores query stringMax Kellermann2014-11-012-0/+28
| | |
| * | Main: run the OS X native event loop after forkingNanoTech2014-10-311-0/+27
| | |
| * | Revert "Main: run the OS X native event loop"NanoTech2014-10-313-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.
| * | PlaylistFile: don't allow empty playlist nameMax Kellermann2014-10-311-0/+4
| | |
| * | decoder/mad: fix negative replay gain valuesMax Kellermann2014-10-281-1/+1
| | | | | | | | | | | | Negating an unsigned integer does not work.
| * | TextInputStream: don't ignore unterminated last lineMax Kellermann2014-10-281-4/+16
| | |
| * | playlist/m3u: recognize the file suffix ".m3u8"Max Kellermann2014-10-262-0/+2
| | |
| * | OutputThread: fall back to PCM if given DSD sample rate is not supportedMax Kellermann2014-10-251-0/+30
| | | | | | | | | | | | | | | Works around the "PCM conversion from f to dsd is not implemented" error message that prevents DSD playback.
| * | decoder/faad: remove workaround for ancient libfaad2 ABI bugMax Kellermann2014-10-252-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!
* | | AllCommands: "commands" returns playlist commands only if playlist_directory ↵Max Kellermann2014-10-253-0/+23
| | | | | | | | | | | | configured
* | | SongSticker, playlist/soundcloud: add missing stdlib.h includeMax Kellermann2014-10-252-0/+2
| | | | | | | | | | | | For free().
* | | SongSticker: don't use GLibMax Kellermann2014-10-251-4/+3
| | |
* | | decoder/wavpack: don't use GLibMax Kellermann2014-10-251-3/+3
| | |
* | | playlist/SoundCloud: don't use GLib for string allocationMax Kellermann2014-10-251-31/+31
| | |
* | | Util/Alloc: add xstrcatdup(), replacing g_strconcat()Max Kellermann2014-10-252-0/+82
| | |