Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
| * | player_thread: disable cross-fading in "single" mode | Max Kellermann | 2012-08-25 | 5 | -8/+48 | |
| | | | | | | | | | | | | | | | | | | | | | | | | | | This commit reimplements the core of the "single" mode. Instead of doing the detection in the playlist code from the outside, it is moved to the player thread, which gets a new option called "border_pause". It will now pause playback exactly at the beginning of the new song, making the feature more reliable. Now that the player thread knows what will happen, it can suppress cross-fading. Fixes mantis tickets 0003055 and 0003166. | |||||
| * | command: make "single" a bool | Max Kellermann | 2012-08-21 | 1 | -1/+1 | |
| | | ||||||
| * | queue_save: save song priorities | Max Kellermann | 2012-08-21 | 6 | -7/+27 | |
| | | ||||||
* | | test/test_queue_priority: fix SIGABRT | Max Kellermann | 2012-08-25 | 2 | -1/+15 | |
| | | ||||||
* | | Database*: fix nullptr dereference when no database is configured | Max Kellermann | 2012-08-22 | 5 | -8/+48 | |
| | | ||||||
* | | fd_util: make C++ safe | Max Kellermann | 2012-08-22 | 1 | -0/+8 | |
| | | ||||||
* | | Makefile.am: swap libdb_plugins.a and -lmpdclient order | Max Kellermann | 2012-08-22 | 1 | -2/+2 | |
| | | | | | | | | | | With some linkers, it is important to specify the static library first, and then libmpdclient. Fixes linker failures. | |||||
* | | configure.ac: set VERSION_MINOR to 18 | Max Kellermann | 2012-08-21 | 1 | -1/+1 | |
| | | | | | | | | Updates the WIN32 version number for the upcoming 0.18 release. | |||||
* | | ProxyDatabase: implement GetSong() | Max Kellermann | 2012-08-16 | 1 | -3/+26 | |
| | | ||||||
* | | ProxyDatabase: clear libmpdclient errors in CheckError() | Max Kellermann | 2012-08-16 | 1 | -1/+2 | |
| | | | | | | | | Auto-recover from soft errors. | |||||
* | | DatabasePlugin: add method ReturnSong() | Max Kellermann | 2012-08-16 | 13 | -14/+85 | |
| | | | | | | | | Allow the plugin to allocate the GetSong() return value. | |||||
* | | Merge branch 'v0.17.x' | Max Kellermann | 2012-08-16 | 3 | -2/+9 | |
|\| | ||||||
| * | playlist_print: fix memory leak | Max Kellermann | 2012-08-16 | 2 | -0/+4 | |
| | | ||||||
| * | playlist_song: pass const song to _check_load_song() | Max Kellermann | 2012-08-16 | 1 | -1/+1 | |
| | | ||||||
| * | playlist_song: fix user-after-free bug | Max Kellermann | 2012-08-16 | 2 | -1/+4 | |
| | | ||||||
* | | ProxyDatabase: pass "detached" objects to visitors | Max Kellermann | 2012-08-15 | 3 | -40/+49 | |
| | | | | | | | | Fixes wrong object URIs with duplicate base names. | |||||
* | | queue: duplicate all song objects | Max Kellermann | 2012-08-15 | 3 | -5/+40 | |
| | | | | | | | | | | Make sure the queue "owns" all song objects, so nobody else can free them. | |||||
* | | player_control: duplicate the song object | Max Kellermann | 2012-08-15 | 5 | -7/+58 | |
| | | | | | | | | | | Make sure the player "owns" the next_song object, so nobody else can free it. | |||||
* | | decoder_control: duplicate the song object | Max Kellermann | 2012-08-15 | 3 | -3/+15 | |
| | | | | | | | | | | Make sure the decoder "owns" the song object, so nobody else can free it. | |||||
* | | Song: add function song_dup_detached() | Max Kellermann | 2012-08-15 | 3 | -1/+81 | |
| | | | | | | | | | | Initial support for "detached" songs that come from the database, but are private copies. | |||||
* | | Song: add function song_equals() | Max Kellermann | 2012-08-15 | 3 | -1/+37 | |
| | | | | | | | | | | decoder_is_current_song() now recognizes different instances of the same physical song. | |||||
* | | Song: move trivial inline functions up | Max Kellermann | 2012-08-15 | 1 | -12/+12 | |
| | | ||||||
* | | DatabasePlugin: add method GetStats() | Max Kellermann | 2012-08-15 | 7 | -63/+148 | |
| | | | | | | | | | | Optimize the ProxyDatabase by invoking "stats" on the peer, instead of visiting all songs. | |||||
* | | DatabasePlugin: add method VisitUniqueTags() | Max Kellermann | 2012-08-15 | 9 | -53/+216 | |
| | | | | | | | | | | Optimize the ProxyDatabase by invoking "list" on the peer, instead of visiting all songs. | |||||
* | | ProxyDatabase: obey visitor return values | Max Kellermann | 2012-08-15 | 1 | -8/+11 | |
| | | ||||||
* | | ProxyDatabasePlugin: add OO wrapper for mpd_entity | Max Kellermann | 2012-08-15 | 1 | -11/+32 | |
| | | | | | | | | Let the C++ compiler take care for freeing the objects safely. | |||||
* | | ProxyDatabasePlugin: move tag table to the global name space | Max Kellermann | 2012-08-15 | 1 | -25/+25 | |
| | | ||||||
* | | db_visitor: delete obsolete header | Max Kellermann | 2012-08-15 | 6 | -61/+0 | |
| | | ||||||
* | | DatabasePrint: remove bogus "nonnull" attributes | Max Kellermann | 2012-08-15 | 1 | -2/+2 | |
| | | ||||||
* | | Merge branch 'v0.17.x' | Max Kellermann | 2012-08-15 | 6 | -7/+12 | |
|\| | | | | | | | | | Conflicts: src/player_thread.c | |||||
| * | player_thread: add local variable "start_ms" | Max Kellermann | 2012-08-15 | 1 | -1/+3 | |
| | | | | | | | | Just in case "song" becomes invalid at some point. | |||||
| * | playlist: fix unprotected player_control access | Max Kellermann | 2012-08-15 | 1 | -1/+5 | |
| | | ||||||
| * | filter/volume: include cleanup | Max Kellermann | 2012-08-15 | 2 | -2/+0 | |
| | | ||||||
| * | mapper: fix potential crash in file permission check | Max Kellermann | 2012-08-15 | 2 | -3/+4 | |
| | | ||||||
* | | decoder_control: add function _is_current_song() | Max Kellermann | 2012-08-15 | 3 | -15/+42 | |
| | | | | | | | | Replaces _current_song(). | |||||
* | | decoder_control: add assertion to dc_get_error() | Max Kellermann | 2012-08-15 | 1 | -0/+1 | |
| | | ||||||
* | | decoder_thread: create GError for mapper failure | Max Kellermann | 2012-08-15 | 1 | -0/+3 | |
| | | | | | | | | Fixes crash. | |||||
* | | Merge branch 'v0.17.x' | Max Kellermann | 2012-08-15 | 6 | -60/+108 | |
|\| | ||||||
| * | doc/user: add wildmidi documentation | Max Kellermann | 2012-08-15 | 1 | -0/+31 | |
| | | ||||||
| * | decoder/fluidsynth: add "sample_rate" setting | Max Kellermann | 2012-08-15 | 3 | -6/+24 | |
| | | ||||||
| * | decoder/fluidsynth: add "soundfont" setting | Max Kellermann | 2012-08-15 | 2 | -6/+38 | |
| | | | | | | | | Replaces the old global "soundfont" which never worked. | |||||
| * | configure.ac: auto-detect libfluidsynth | Max Kellermann | 2012-08-15 | 3 | -12/+3 | |
| | | | | | | | | | | Now that the libfluidsynth API was sanitized, we can enable the plugin automatically if libfluidsynth is installed. | |||||
| * | decoder/fluidsynth: stop playback at end of file | Max Kellermann | 2012-08-15 | 2 | -5/+5 | |
| | | | | | | | | Use libfluidsynth's new function fluid_player_get_status(). | |||||
| * | decoder/fluidsynth: don't duplicate path | Max Kellermann | 2012-08-15 | 1 | -6/+1 | |
| | | | | | | | | The libfluidsynth now accepts const strings. | |||||
| * | decoder/fluidsynth: check if file is really a MIDI | Max Kellermann | 2012-08-15 | 2 | -4/+2 | |
| | | | | | | | | Use fluid_is_midifile() to verify the file format. | |||||
| * | decoder/fluidsynth: remove throttle (requires libfluidsynth 1.1) | Max Kellermann | 2012-08-15 | 4 | -21/+4 | |
| | | | | | | | | | | The libfluidsynth API is now sane, and does not require real-time decoding. | |||||
* | | Merge branch 'v0.17.x' | Max Kellermann | 2012-08-14 | 14 | -139/+278 | |
|\| | ||||||
| * | log: store duplicated path string | Max Kellermann | 2012-08-14 | 3 | -31/+32 | |
| | | | | | | | | | | | | | | Don't free the string right after calling log_init_file(). Add a new function log_deinit() that frees the string on shutdown. This fixes cycling the log file after SIGHUP (Mantis ticket 0003524). | |||||
| * | output/jack: implement method delay() | Max Kellermann | 2012-08-14 | 1 | -4/+11 | |
| | | | | | | | | Eliminate the g_usleep() call. | |||||
| * | output/pulse: implement method delay() | Max Kellermann | 2012-08-14 | 1 | -7/+21 | |
| | | | | | | | | Reduce command latency while paused. |