Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | decoder/Control: State::ERROR is illegal | Max Kellermann | 2015-11-11 | 1 | -1/+2 |
| | | | | | The state ERROR can only be entered during decoder initialization, and Seek() may only be called after initialization has been finished. | ||||
* | decoder/Control: use switch/case in Seek() | Max Kellermann | 2015-11-11 | 1 | -2/+13 |
| | |||||
* | player/Control: use class ScopeLock | Max Kellermann | 2015-11-11 | 2 | -36/+19 |
| | |||||
* | player/Control: move code to ClearError() | Max Kellermann | 2015-11-11 | 2 | -6/+6 |
| | |||||
* | player/Control: move code to SeekLocked() | Max Kellermann | 2015-11-11 | 2 | -5/+14 |
| | |||||
* | player/Control: add Lock prefix to locking method names | Max Kellermann | 2015-11-11 | 9 | -44/+44 |
| | |||||
* | StateFile: use StringAfterPrefix() instead of StringStartsWith() | Max Kellermann | 2015-11-11 | 4 | -41/+30 |
| | |||||
* | db/simple: use StringAfterPrefix() instead of StringStartsWith() | Max Kellermann | 2015-11-11 | 2 | -21/+20 |
| | |||||
* | util/StringPointer: add method empty() | Max Kellermann | 2015-11-11 | 1 | -0/+6 |
| | |||||
* | util/StringView: add method Literal() | Max Kellermann | 2015-11-06 | 1 | -2/+12 |
| | |||||
* | util/StringCompare: use StringView to simplify inline implementations | Max Kellermann | 2015-11-06 | 2 | -31/+14 |
| | |||||
* | playlist/soundcloud: make key_str "static const" | Max Kellermann | 2015-11-06 | 1 | -1/+1 |
| | |||||
* | db/update/InotifyQueue: use StringAfterPrefix() | Max Kellermann | 2015-11-06 | 1 | -6/+6 |
| | |||||
* | input/alsa: use StringAfterPrefix() | Max Kellermann | 2015-11-06 | 1 | -3/+2 |
| | |||||
* | util/UriUtil: use StringAfterPrefix() instead of memcmp() | Max Kellermann | 2015-11-06 | 1 | -9/+9 |
| | |||||
* | util/UriUtil: move code to SkipUriScheme() | Max Kellermann | 2015-11-06 | 1 | -6/+15 |
| | |||||
* | util/UriUtil: make variables more local | Max Kellermann | 2015-11-06 | 1 | -7/+4 |
| | |||||
* | util/StringCompare: add StringIsEmpty() | Max Kellermann | 2015-11-06 | 13 | -16/+37 |
| | |||||
* | util/StringCompare: use strncmp() instead of memcmp() in StringStartsWith() | Max Kellermann | 2015-11-06 | 2 | -3/+4 |
| | | | | | Some optimized implementations of memcmp() may not start from the beginning of the string, and may thus segfault. | ||||
* | util/StringUtil: move comparison functions to StringCompare.cxx | Max Kellermann | 2015-11-06 | 30 | -153/+232 |
| | |||||
* | tag/id3: convert path from "wchar_t*" to "char*" for error message | Max Kellermann | 2015-11-06 | 1 | -1/+3 |
| | |||||
* | player/Thread: call DecoderCommand::SEEK only on existing decoder | Max Kellermann | 2015-11-05 | 1 | -17/+22 |
| | | | | | If the decoder was just started, it already seeks to the desired position. | ||||
* | player/Thread: move code to WaitDecoderStartup() | Max Kellermann | 2015-11-05 | 1 | -7/+21 |
| | |||||
* | player/Thread: move player_command_finished() to PlayerControl | Max Kellermann | 2015-11-05 | 2 | -12/+10 |
| | |||||
* | player/Thread: copy pc.seek_time in ActivateDecoder() | Max Kellermann | 2015-11-05 | 1 | -2/+1 |
| | | | | | If this gets called while seeking, do the right thing. This moves the elapsed_time setter from method Run(), which is now redundant. | ||||
* | player/Control: initialize seek_time in EnqueueSongLocked() | Max Kellermann | 2015-11-05 | 2 | -6/+3 |
| | | | | Allows removing a few special cases in the player thread. | ||||
* | player/Thread: remove decoder error check from ActivateDecoder() | Max Kellermann | 2015-10-28 | 1 | -37/+8 |
| | | | | | | It is futile to check for decoder errors before the decoder has finished startup. At this time, it's unlikely that the decoder has already failed. | ||||
* | player/Thread: rename WaitForDecoder() to ActivateDecoder() | Max Kellermann | 2015-10-28 | 1 | -10/+15 |
| | | | | .. and fix its API documentation. | ||||
* | player/Thread: move code to ForwardDecoderError() | Max Kellermann | 2015-10-27 | 1 | -6/+22 |
| | |||||
* | player/Thread: clear pc.next_song earlier in WaitForDecoder() | Max Kellermann | 2015-10-27 | 1 | -4/+3 |
| | |||||
* | player/Control: use CANCEL to clear next_song in Seek() | Max Kellermann | 2015-10-27 | 1 | -1/+5 |
| | | | | | Assigning nullptr to next_song may disrupt the player thread and render undefined behavior. | ||||
* | player/Thread: merge the cross_fading flag into enum CrossFadeState | Max Kellermann | 2015-10-27 | 1 | -22/+25 |
| | |||||
* | player/Thread: move ResetCrossFade() calls to where pipes are set | Max Kellermann | 2015-10-27 | 1 | -3/+8 |
| | | | | | Move ResetCrossFade() to where cross-fading would actually break, to make the cross-fading state more reliable. | ||||
* | player/Thread: add method ResetCrossFade() | Max Kellermann | 2015-10-27 | 1 | -2/+10 |
| | |||||
* | player/Thread: more CrossFadeState documentation | Max Kellermann | 2015-10-27 | 1 | -1/+16 |
| | |||||
* | player/Thread: automatic CrossFadeState enum values | Max Kellermann | 2015-10-27 | 1 | -4/+4 |
| | |||||
* | player/Thread: move enum CrossFadeState into the Player class | Max Kellermann | 2015-10-27 | 1 | -7/+5 |
| | |||||
* | command/queue: add range parameter to plchanges and plchangesposid | Max Kellermann | 2015-10-27 | 6 | -17/+52 |
| | |||||
* | pcm/Order: new library to convert from FLAC to ALSA channel order | Max Kellermann | 2015-10-27 | 6 | -2/+201 |
| | | | | | | | | | | | This new library is integrated in the PcmExport class and (if enabled) converts MPD's channel order (= FLAC channel order) to ALSA channel order. This fixes: http://bugs.musicpd.org/view.php?id=3147 and http://bugs.musicpd.org/view.php?id=3255 | ||||
* | AudioFormat: define that channel order follows the FLAC convention | Max Kellermann | 2015-10-27 | 1 | -2/+13 |
| | | | | | Basic definition to solve http://bugs.musicpd.org/view.php?id=3147 and http://bugs.musicpd.org/view.php?id=3255 | ||||
* | Merge tag 'v0.19.11' | Max Kellermann | 2015-10-27 | 7 | -23/+43 |
|\ | |||||
| * | gme: don't loop forever, fall back to GME's default play length | Max Kellermann | 2015-10-26 | 1 | -3/+3 |
| | | | | | | | | Fixes http://bugs.musicpd.org/view.php?id=4432 | ||||
| * | decoder/gme: free the gme_info_t as early as possible | Max Kellermann | 2015-10-26 | 1 | -6/+7 |
| | | |||||
| * | decoder/gme: call decoder_seek_error() on seek error | Max Kellermann | 2015-10-26 | 1 | -2/+4 |
| | | |||||
| * | output/Command: flush the mixer cache when enabling/disabling output | Max Kellermann | 2015-10-26 | 1 | -0/+8 |
| | | | | | | | | Fixes mixer lag (http://bugs.musicpd.org/view.php?id=4425). | ||||
| * | decoder/ffmpeg: fix crash due to wrong avio_alloc_context() call | Max Kellermann | 2015-10-26 | 1 | -4/+13 |
| | | | | | | | | | | | | | | | | Allocate the buffer dynamically using av_malloc(), and free AVIOContext.buffer in the destructor, as mandated by the libavformat documentation. Fixes http://bugs.musicpd.org/view.php?id=4446 | ||||
| * | decoder/mpcdec: use SampleTraits<SampleFormat::S24_P32> | Max Kellermann | 2015-10-16 | 1 | -11/+13 |
| | | | | | | | | | | | | Eliminates some duplicate code, and as a side effect, this works around clang 3.8 compiler warning because a negative value was shifted. | ||||
| * | decoder/mpcdec: use Clamp() | Max Kellermann | 2015-10-16 | 1 | -6/+2 |
| | | |||||
| * | unix/Daemon, playlist/...: remove unused Domain variables | Max Kellermann | 2015-10-16 | 7 | -21/+0 |
| | | |||||
| * | encoder/flac: fix crash with 32 bit playback | Max Kellermann | 2015-10-16 | 1 | -2/+2 |
| | | | | | | | | | | | | | | Copy to encoder->audio_format *after* adjusting the sample format to S24_P32. Fixes http://bugs.musicpd.org/view.php?id=4433 |