aboutsummaryrefslogtreecommitdiffstats
path: root/src (follow)
Commit message (Collapse)AuthorAgeFilesLines
...
* | QueueSave: use the long format to save partial songsMax Kellermann2014-07-121-1/+6
| | | | | | | | | | Previously, only streams were saved with range and tags, but this is necessary for all "partial" songs (e.g. CUE tracks).
* | QueueCommands: new command "rangeid"Max Kellermann2014-07-125-0/+123
| | | | | | | | Manipulates the playback range of a queued song.
* | PlaylistSong, CueParser: don't override Tag::timeMax Kellermann2014-07-122-11/+0
| | | | | | | | | | Now that Song::GetDuration() is used (which considers start_ms and end_ms), we don't need to override the Tag's duration value.
* | SongPrint: use DetachedSong::GetDuration()Max Kellermann2014-07-121-1/+5
| | | | | | | | Fixes the bogus duration of the last track in a CUE sheet.
* | TagPrint: split tag_print()Max Kellermann2014-07-122-3/+12
| | | | | | | | | | Add one method that prints only the tag values, but not the song duration.
* | Tag: add class const_iterator and methods begin(), end()Max Kellermann2014-07-1212-45/+88
| | | | | | | | Enables using range-based "for".
* | DecoderBuffer: implement _skip() using decoder_skip()Max Kellermann2014-07-121-17/+8
| |
* | DecoderBuffer: add method _need()Max Kellermann2014-07-123-31/+42
| | | | | | | | Move code from the FAAD decoder plugin.
* | DecoderBuffer: remove unused method _is_full()Max Kellermann2014-07-122-10/+0
| |
* | decoder/faad: eliminate the adts_find_frame() loopMax Kellermann2014-07-121-5/+2
| | | | | | | | | | This loop is completely unnecessary. We just need to find the first ADTS frame and feed it into NeAACDecInit().
* | decoder/faad: split faad_stream_decode()Max Kellermann2014-07-121-10/+16
| | | | | | | | Eliminate duplicate cleanup code.
* | DecoderBuffer: remove unused method _is_empty()Max Kellermann2014-07-122-10/+0
| |
* | Merge branch 'v0.18.x'Max Kellermann2014-07-123-54/+99
|\|
| * decoder/faad: estimate song duration for remote filesMax Kellermann2014-07-121-0/+22
| | | | | | | | | | | | | | | | 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.
| * DecoderBuffer: add method _available()Max Kellermann2014-07-122-0/+13
| |
| * DecoderBuffer: add method _get_stream()Max Kellermann2014-07-122-0/+10
| |
| * decoder/faad: bail out early if sample rate is invalidMax Kellermann2014-07-121-0/+2
| |
| * decoder/faad: use adts_check_frame() in faad_song_duration()Max Kellermann2014-07-121-2/+1
| | | | | | | | Eliminate more duplicate code.
| * decoder/faad: test "seekable" after ADTS frame checkMax Kellermann2014-07-121-1/+5
| | | | | | | | | | Don't bother to check for ADIF just because the stream is not seekable.
| * decoder/faad: move code to faad_decoder_new()Max Kellermann2014-07-121-14/+17
| | | | | | | | Merge some duplicate code.
| * decoder/faad: remove unnecessary readMax Kellermann2014-07-121-2/+0
| | | | | | | | Eliminate some overhead when the caller doesn't need the buffer.
| * DecoderBuffer: add "pure" attributesMax Kellermann2014-07-121-0/+4
| |
| * DecoderBuffer: add method _clear()Max Kellermann2014-07-123-8/+12
| |
| * decoder/faad: check sample_rate, not frames_per_secondMax Kellermann2014-07-111-2/+4
| | | | | | | | Checking the integer is faster, easier and more reliable.
| * decoder/faad: make variables more localMax Kellermann2014-07-111-71/+49
| |
| * decoder/faad: use MAX_CHANNELSMax Kellermann2014-07-111-4/+2
| | | | | | | | .. instead of declaring a new constant.
* | decoder/sndfile: implement scan_stream() instead of scan_file()Max Kellermann2014-07-111-5/+6
| |
* | decoder/sndfile: make variables more localMax Kellermann2014-07-111-10/+7
| |
* | decoder/sndfile: support more tag typesMax Kellermann2014-07-111-0/+4
| |
* | decoder/sndfile: add str_type to TagType tableMax Kellermann2014-07-111-3/+11
| |
* | decoder/sndfile: move code to sndfile_handle_tag()Max Kellermann2014-07-111-15/+12
| |
* | decoder/sndfile: log libsndfile version on startupMax Kellermann2014-07-111-1/+8
| |
* | PlaylistEdit: fix typo in code commentMax Kellermann2014-07-111-1/+1
| |
* | Merge branch 'v0.18.x'Max Kellermann2014-07-1110-33/+144
|\|
| * decoder/sndfile: use decoder_read_full()Max Kellermann2014-07-111-16/+6
| | | | | | | | | | Replaces the loop in sndfile_vio_read(), eliminating duplicate and fragile code.
| * decoder/sndfile: use decoder_read()Max Kellermann2014-07-111-16/+22
| | | | | | | | .. instead of InputStream::LockRead(). The former is cancellable.
| * decoder/sndfile: log seek errorsMax Kellermann2014-07-111-1/+4
| |
| * decoder/audiofile: log seek errorsMax Kellermann2014-07-111-0/+1
| |
| * decoder/audiofile: fix typo in commentMax Kellermann2014-07-111-1/+1
| |
| * PlaylistEdit: postpone UpdateQueuedSong() when adding multiple songsMax Kellermann2014-07-117-1/+109
| | | | | | | | | | | | | | | | | | | | 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.
| * QueueCommands: make "result" more localMax Kellermann2014-07-111-3/+2
| |
| * Playlist: randomize next song when enabling "random" mode while not playingMax Kellermann2014-07-111-1/+3
| | | | | | | | | | | | 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.
| * PlaylistControl: update code commentMax Kellermann2014-07-111-1/+1
| |
* | input/curl: options "verify_peer" and "verify_host"Max Kellermann2014-07-111-0/+8
| |
* | fs/StandardDirectory: look for cache dir in environment, not user-dirsMantas Mikulėnas2014-07-111-3/+15
| | | | | | | | | | The XDG cache directory is part of the "base directories" spec like $XDG_CONFIG_HOME, not "user directories".
* | input/async: more API documentationMax Kellermann2014-07-101-0/+26
| |
* | decoder/audiofile: log libaudiofile errorsMax Kellermann2014-07-101-4/+15
| |
* | decoder/audiofile: make variables more localMax Kellermann2014-07-101-28/+24
| |
* | decoder/audiofile: implement scan_stream() instead of scan_file()Max Kellermann2014-07-101-23/+23
| |
* | decoder/audiofile: use audiofile_get_duration() in _stream_decode()Max Kellermann2014-07-101-5/+2
| |