aboutsummaryrefslogtreecommitdiffstats
path: root/NEWS (follow)
Commit message (Collapse)AuthorAgeFilesLines
* PlaylistFile: don't allow empty playlist nameMax Kellermann2014-11-021-0/+1
|
* playlist/m3u: recognize the file suffix ".m3u8"Max Kellermann2014-11-021-0/+2
|
* decoder/faad: remove workaround for ancient libfaad2 ABI bugMax Kellermann2014-11-021-0/+1
| | | | | | | | | | | | | | | | | | | | | | | | 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/+2
|
* configure.ac: prepare for 0.18.17Max Kellermann2014-11-021-0/+2
|
* release v0.18.16Max Kellermann2014-09-261-1/+1
|
* configure.ac: fix DSD breakage due to typoMax Kellermann2014-09-261-0/+1
|
* configure.ac: prepare for 0.18.16Max Kellermann2014-09-261-0/+2
|
* release v0.18.15Max Kellermann2014-09-261-1/+1
|
* OutputThread: retain negative mix ratioMax Kellermann2014-09-181-0/+1
| | | | Fixes MixRamp breakage.
* command/list: reset used size after the list has been processedAndrzej Rybczak2014-09-181-0/+2
|
* thread/Posix{Cond,Mutex}: don't ues PTHREAD_*_INITIALIZER on NetBSDMax Kellermann2014-09-131-0/+1
| | | | | | | | | | On NetBSD, PTHREAD_MUTEX_INITIALIZER and PTHREAD_COND_INITIALIZER are not compatible with C++11 "constexpr" (see Mantis ticket 0004110). As a workaround, don't ues "constexpr", and use the functions pthread_mutex_init(), pthread_mutex_destroy(), pthread_cond_init() and pthread_cond_destroy() instead. This adds some runtime overhead, but is portable to POSIX implementations that have awkward initializer macros.
* configure.ac: prepare for 0.18.15Max Kellermann2014-09-131-0/+2
|
* release v0.18.14Max Kellermann2014-09-111-1/+1
|
* decoder/ffmpeg: pass MIME type to ffmpeg/libav version 11Max Kellermann2014-09-071-0/+1
| | | | | | | That attribute was uninitialized before, which could crash libavformat. See Debian bug 760669
* DecoderThread: clear the pipe when handling late SEEKMax Kellermann2014-09-071-0/+1
| | | | | See code comment. Fixes assertion failure in decoder_command_finished().
* decoder/audiofile: fix crash after seekingMax Kellermann2014-09-061-0/+2
| | | | | | Log call was added to the wrong branch. Fixes regression by commit ca1a1149
* protocol/ArgParser: fix integer overflow in parse_range()Max Kellermann2014-09-041-0/+2
| | | | | | | | | | | | | Casting std::numeric_limits<unsigned>::max() to "long" leads to an overflow if sizeof(unsigned)==sizeof(long), and the result will be -1. This happens on some 32 bit architectures, for example ARM and WIN32. Workaround: use std::numeric_limits<int>::max(), which is the largest signed integer. Since sizeof(long)>=sizeof(int), this will never overflow. Fixes Mantis ticket 0004080.
* configure.ac: prepare for 0.18.14Max Kellermann2014-09-031-0/+2
|
* release v0.18.13Max Kellermann2014-08-311-1/+1
|
* PlaylistControl: use SeekSongOrder(current) to keep current songMax Kellermann2014-08-311-0/+2
| | | | | | The "current" attribute is a "song order", not a "song position". This is usually the same - except in random mode. Fixes Mantis ticket 0004073.
* output/alsa: fix endless loop at end of file in dsd_usb modeMax Kellermann2014-08-311-0/+2
|
* decoder/gme: fix song durationMax Kellermann2014-08-291-0/+1
| | | | The unit of gme_info_t::length is milliseconds, not centiseconds.
* event/TimeoutMonitor: reset "active" flag before invoking OnTimeout()Max Kellermann2014-08-241-0/+1
| | | | | | The IsActive() method returned true even if the timer was not active, after it completed once. This broke the state file timer, and the state file was not saved periodically.
* system/ByteOrder: <endian.h> is a non-standard header that only Linux provides.Thomas Klausner2014-08-231-0/+1
|
* decoer/dsdiff: fix endless loop on malformed fileMax Kellermann2014-08-211-1/+1
| | | | Same bug as in the previous commit.
* decoer/dsf: fix endless loop on malformed fileMax Kellermann2014-08-211-0/+1
| | | | | | | When the data chunk size is not a multiple of the frame size, the last partial frame lead to an endless loop. We fix this by checking chunk_sze>=frame instead of chunk_sze>0. This way, the partial frame is simply skipped.
* decoder/ffmpeg: use avcodec_descriptor_get() to determine codec nameMax Kellermann2014-08-131-0/+2
| | | | | | In version 11, both ffmpeg and libav deprecate AVCodecContext::codec_name. The function avcodec_descriptor_get() has been introduced long ago.
* configure.ac: prepare for 0.18.13Max Kellermann2014-08-021-0/+2
|
* release v0.18.12Max Kellermann2014-07-301-1/+1
|
* decoder/dsdiff: fix metadata parser bug (uninitialized variables)Max Kellermann2014-07-121-0/+1
|
* decoder/faad: estimate song duration for remote filesMax Kellermann2014-07-121-0/+1
| | | | | | | | 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/sndfile: use decoder_read()Max Kellermann2014-07-111-0/+1
| | | | .. instead of InputStream::LockRead(). The former is cancellable.
* PlaylistEdit: postpone UpdateQueuedSong() when adding multiple songsMax Kellermann2014-07-111-0/+1
| | | | | | | | | | Implement a "bulk" edit mode that postpones both UpdateQueuedSong() and OnModified(). This way, the playlist version gets incremented only once. More importantly: when adding multiple songs to a queue that consists of only one song, the first song that got added will always be played next. By postponing this choice, all newly added songs get a chance to become the next song. Fixes the second (and last) part of Mantis ticket 0004005.
* Playlist: randomize next song when enabling "random" mode while not playingMax Kellermann2014-07-111-0/+1
| | | | | | Don't restore the current song after shufflung when MPD is stopped (but still remembers the current song internally). Fixes the first part of Mantis ticket 0004005.
* decoder/dsd: use decoder_read_full() where appropriateJoff2014-07-091-0/+1
| | | | | | | Addresses Mantis ticket 0004015. [mk: use decoder_read_full() only when needed, and a few formal changes]
* decoder/audiofile: use decoder_read_full()Max Kellermann2014-07-091-0/+1
| | | | | Works around WAV stream playback bug, because libaudiofile does not like partial reads (Mantis 0004028).
* decoder/audiofile: use decoder_read()Max Kellermann2014-07-091-0/+2
| | | | | .. instead of InputStream::LockRead(). The former is cancellable.
* db/proxy: fall back to recursive walk on old libmpdclient/MPDMax Kellermann2014-06-231-0/+1
| | | | | Error message was 'too few arguments for "find"' because the "base" constraint was not supported, and no other constraints remained.
* db/proxy: use mpd_song_get_{start,end}() only with libmpdclient >= 2.3Max Kellermann2014-06-231-0/+2
|
* configure.ac: prepare for 0.18.12Max Kellermann2014-06-231-0/+2
|
* release v0.18.11Max Kellermann2014-05-121-1/+1
|
* decoder/OggUtil: allow skipping up to 32 kB after seekMax Kellermann2014-04-291-0/+2
| | | | | | | Fixes missing song length on high-latency Opus files. According to tests with 320 kbit/s opus files with 60ms packets, we need to skip up to 29 kB.
* DeferredMonitor: fix race condition when using GLib event loopMax Kellermann2014-04-261-0/+1
| | | | | | | | | Turns out the lock-free code using atomics was not thread-safe. The given callback could be invoked by GLib before the source_id attribute was assigned. This commit changes the DeferredMonitor class to use a Mutex to block the event loop until source_id is assigned. This bug does not exist in the 0.19 branch because it does not use the GLib main loop anymore.
* configure.ac: prepare for 0.18.11Max Kellermann2014-04-261-0/+2
|
* release v0.18.10Max Kellermann2014-04-101-1/+1
|
* decoder/sndfile: work around libsndfile bug on partial readMarcello Desantis2014-04-091-0/+1
|
* PlaylistEdit: don't interrupt playback when current song gets deletedWeng Xuetian2014-04-091-0/+1
|
* decoder/ffmpeg: handle unknown stream start timeMax Kellermann2014-03-181-0/+1
|
* decoder/ffmpeg: pass AVSEEK_FLAG_ANY to av_seek_frame()Max Kellermann2014-03-181-0/+1
| | | | | | This corrects a major mistake from commit 724a59aa - there was one small thing that commit was supposed to do, and it failed. AV_TIME_BASE is not a seek flag.