Commit message (Collapse) | Author | Files | Lines | ||
---|---|---|---|---|---|
2015-06-21 | PlayerThread: start the decoder on PlayerCommand::QUEUE | Max Kellermann | 1 | -0/+6 | |
Fixes missing SongBorder() call, which causes "single" mode breakage. | |||||
2015-01-01 | Copyright year 2015 | Max Kellermann | 1 | -1/+1 | |
2014-08-29 | CrossFade: pass total_time as SignedSongTime instance | Max Kellermann | 1 | -1/+1 | |
2014-08-29 | MusicChunk: use SignedSongTime for the time stamp | Max Kellermann | 1 | -1/+1 | |
2014-08-29 | MultipleOutputs: use SignedSongTime for elapsed_time | Max Kellermann | 1 | -2/+2 | |
2014-08-29 | PlayerThread: use SongTime for elapsed_time | Max Kellermann | 1 | -8/+8 | |
2014-08-29 | PlayerControl: use SignedSongTime for the song duration | Max Kellermann | 1 | -11/+11 | |
2014-08-29 | DecoderControl: use SignedSongTime for the song duration | Max Kellermann | 1 | -2/+2 | |
2014-08-29 | Tag: use SignedSongTime for the song duration | Max Kellermann | 1 | -2/+2 | |
2014-08-28 | DecoderControl: use std::chrono::duration for start_ms and end_ms | Max Kellermann | 1 | -1/+1 | |
2014-08-28 | DetachedSong: use std::chrono::duration for start_ms and end_ms | Max Kellermann | 1 | -10/+10 | |
2014-08-27 | PlayerControl: use std::chrono::duration for Seek() | Max Kellermann | 1 | -9/+10 | |
2014-08-27 | PlayerThread: check if total_time is valid before using it | Max Kellermann | 1 | -1/+1 | |
2014-08-27 | DecoderControl: use std::chrono::duration for Seek() | Max Kellermann | 1 | -1/+1 | |
2014-08-16 | PlayerThread: rename player_create() to StartPlayerThread() | Max Kellermann | 1 | -1/+1 | |
2014-08-12 | MusicChunk: rename struct to MusicChunk | Max Kellermann | 1 | -6/+6 | |
2014-02-21 | PlayerListener: new interface to replace GlobalEvents access | Max Kellermann | 1 | -4/+4 | |
2014-01-28 | OutputAll: convert to class, move instance to class Partition | Max Kellermann | 1 | -23/+23 | |
Another big chunk of code for multi-player support. | |||||
2014-01-24 | decoder/*: move to decoder/plugins/ | Max Kellermann | 1 | -2/+2 | |
2014-01-23 | output/*: move to output/plugins/ | Max Kellermann | 1 | -1/+1 | |
2014-01-23 | thread/Name: set thread names | Max Kellermann | 1 | -0/+3 | |
For debugging. | |||||
2014-01-13 | copyright year 2014 | Max Kellermann | 1 | -1/+1 | |
2014-01-09 | DetachedSong: fork of struct Song | Max Kellermann | 1 | -40/+30 | |
From now on, struct Song will be used by the database only, and DetachedSong will be used by everybody else. DetachedSong is easier to use, but Song has lower overhead. | |||||
2014-01-08 | PlayerThread: use Song references | Max Kellermann | 1 | -15/+13 | |
2013-12-24 | PlayerThread: log the last song that was played | Max Kellermann | 1 | -1/+4 | |
2013-11-28 | include cleanup using iwyu | Max Kellermann | 1 | -1/+0 | |
2013-11-08 | PlayerThread: fix stuck MPD after song change (0.18.2 regression) | Max Kellermann | 1 | -4/+8 | |
Commit 77c63511 caused MPD to become stuck right after a song change. The problem was that at some point, the MusicBuffer became full, and the DecoderThread working on the next song waits for the PlayerThread. However, the PlayerThread was stuck in a loop of g_usleep() calls, and never bothered to tell the DecoderThread that the MusicBuffer is not full anymore. This bug is very old, but its chance to occur went from nearly 0% to nearly 100%. The fix is to wake up the DecoderThread before waiting for it. As a side effect, I replaced the g_usleep() call with a Cond::Wait() call. | |||||
2013-11-06 | PlayerThread: reduce the number of DecoderThread wakeups | Max Kellermann | 1 | -2/+14 | |
After the number of decoded chunks has fallen below the threshold, the PlayerThread woke up the DecoderThread over and over. This commit adds a boolean flag that avoids these duplicate wakeups, and thus reduces the number of system calls. | |||||
2013-11-06 | PlayerThread: enable buffering when starting playback | Max Kellermann | 1 | -1/+1 | |
For some reason, this got lost in commit 975deca8. Re-enabling this fixes stuttering at the beginning of radio streams. | |||||
2013-11-04 | Log: add level "DEFAULT" | Max Kellermann | 1 | -1/+1 | |
Map LogLevel::INFO to G_LOG_LEVEL_INFO, and LogLevel::DEFAULT to G_LOG_LEVEL_MESSAGE. Now client connect/disconnect message are only logged on log_level "secure". | |||||
2013-10-30 | PcmMix: use negative value instead of NaN for addition | Max Kellermann | 1 | -3/+1 | |
Avoid NaN to allow -ffast-math. | |||||
2013-10-30 | CrossFade: use negative value for invalid mixramp_delay | Max Kellermann | 1 | -1/+1 | |
Avoid NaN to allow -ffast-math. | |||||
2013-10-29 | PlayerControl: move attributes to struct CrossFadeSettings | Max Kellermann | 1 | -12/+10 | |
2013-10-28 | DecoderControl: convert mutex and client_cond to a reference | Max Kellermann | 1 | -19/+12 | |
Share the Mutex between the DecoderThread and the PlayerThread. This simplifies synchronization between the two threads and fixes a freeze problem: while the PlayerThread waits for the DeocderThread, it cannot answer requests from the main thread, and the main thread will block until the DecoderThread finishes. | |||||
2013-10-28 | player_control: rename to PlayerControl | Max Kellermann | 1 | -9/+9 | |
2013-10-28 | decoder_control: rename to DecoderControl | Max Kellermann | 1 | -4/+4 | |
2013-10-26 | DecoderControl: add MixRamp getters | Max Kellermann | 1 | -2/+2 | |
2013-10-22 | Playlist: copy stream tags from the PlayerThread | Max Kellermann | 1 | -2/+8 | |
Finally restores an important feature that has been broken for several months when the PlayerThread started working with Song copies instead of pointers to the Queue's Song instances (commit e96779d). | |||||
2013-10-21 | Song: pass reference to song_equals() | Max Kellermann | 1 | -1/+1 | |
2013-10-19 | *: use references instead of pointers | Max Kellermann | 1 | -3/+3 | |
2013-10-19 | PlayerThread: Only drop 0 length packets without tags | Ben Boeckel | 1 | -1/+1 | |
Fixes a regression from 752dfb3d95482c562e5d24c6ea839c4815de9a6d which caused the current chunk to be flushed as soon as new replaygain information was found. If this occurs on a tag chunk, it has no data (length 0) and is then skipped before pushing it to all of the outputs. This change allows 0-length chunks through if they contain a tag and they are now appearing in mplayer and mpv properly. | |||||
2013-10-17 | Thread/Thread: replacement library for GThread | Max Kellermann | 1 | -13/+8 | |
2013-10-17 | Song: GetURI() returns std::string | Max Kellermann | 1 | -7/+6 | |
2013-10-02 | Log: new logging library API | Max Kellermann | 1 | -9/+11 | |
Prepare to migrate away from GLib. Currently, we're still using GLib as a backend. | |||||
2013-09-27 | PlayerThread: convert struct player to a class | Max Kellermann | 1 | -14/+17 | |
2013-09-27 | PlayerThread: use strictly typed enum | Max Kellermann | 1 | -14/+14 | |
2013-09-27 | PlayerControl: use strictly typed enums | Max Kellermann | 1 | -44/+44 | |
2013-09-27 | PlayerThread: move code to player_control::CommandFinished() | Max Kellermann | 1 | -21/+12 | |
2013-09-27 | PlayerThread: use nullptr instead of NULL | Max Kellermann | 1 | -37/+37 | |
2013-09-26 | PlayerThread: unlock/lock in player_task() | Max Kellermann | 1 | -8/+3 | |