Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
* | Merge branch 'v0.18.x' | Max Kellermann | 2014-07-12 | 1 | -12/+9 | |
|\ | ||||||
| * | decoder/dsdiff: simplify dsdlib_skip() call | Max Kellermann | 2014-07-12 | 1 | -4/+3 | |
| | | ||||||
| * | decoder/dsdiff: simplify loop condition, merge branches | Max Kellermann | 2014-07-12 | 1 | -7/+2 | |
| | | ||||||
| * | decoder/dsdiff: ignore garbage null byte at end of file | Max Kellermann | 2014-07-12 | 1 | -1/+1 | |
| | | | | | | | | | | Failure to read another chunk header is not fatal. Continue to read metadata. | |||||
| * | decoder/dsdiff: fix metadata parser bug (uninitialized variables) | Max Kellermann | 2014-07-12 | 1 | -1/+4 | |
| | | ||||||
* | | PlaylistSong: always merge tags and LastModified | Max Kellermann | 2014-07-12 | 1 | -12/+2 | |
| | | ||||||
* | | QueueSave: use the long format to save partial songs | Max Kellermann | 2014-07-12 | 1 | -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 Kellermann | 2014-07-12 | 5 | -0/+123 | |
| | | | | | | | | Manipulates the playback range of a queued song. | |||||
* | | PlaylistSong, CueParser: don't override Tag::time | Max Kellermann | 2014-07-12 | 2 | -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 Kellermann | 2014-07-12 | 1 | -1/+5 | |
| | | | | | | | | Fixes the bogus duration of the last track in a CUE sheet. | |||||
* | | TagPrint: split tag_print() | Max Kellermann | 2014-07-12 | 2 | -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 Kellermann | 2014-07-12 | 12 | -45/+88 | |
| | | | | | | | | Enables using range-based "for". | |||||
* | | DecoderBuffer: implement _skip() using decoder_skip() | Max Kellermann | 2014-07-12 | 1 | -17/+8 | |
| | | ||||||
* | | DecoderBuffer: add method _need() | Max Kellermann | 2014-07-12 | 3 | -31/+42 | |
| | | | | | | | | Move code from the FAAD decoder plugin. | |||||
* | | DecoderBuffer: remove unused method _is_full() | Max Kellermann | 2014-07-12 | 2 | -10/+0 | |
| | | ||||||
* | | decoder/faad: eliminate the adts_find_frame() loop | Max Kellermann | 2014-07-12 | 1 | -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 Kellermann | 2014-07-12 | 1 | -10/+16 | |
| | | | | | | | | Eliminate duplicate cleanup code. | |||||
* | | DecoderBuffer: remove unused method _is_empty() | Max Kellermann | 2014-07-12 | 2 | -10/+0 | |
| | | ||||||
* | | Merge branch 'v0.18.x' | Max Kellermann | 2014-07-12 | 3 | -54/+99 | |
|\| | ||||||
| * | decoder/faad: estimate song duration for remote files | Max Kellermann | 2014-07-12 | 1 | -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 Kellermann | 2014-07-12 | 2 | -0/+13 | |
| | | ||||||
| * | DecoderBuffer: add method _get_stream() | Max Kellermann | 2014-07-12 | 2 | -0/+10 | |
| | | ||||||
| * | decoder/faad: bail out early if sample rate is invalid | Max Kellermann | 2014-07-12 | 1 | -0/+2 | |
| | | ||||||
| * | decoder/faad: use adts_check_frame() in faad_song_duration() | Max Kellermann | 2014-07-12 | 1 | -2/+1 | |
| | | | | | | | | Eliminate more duplicate code. | |||||
| * | decoder/faad: test "seekable" after ADTS frame check | Max Kellermann | 2014-07-12 | 1 | -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 Kellermann | 2014-07-12 | 1 | -14/+17 | |
| | | | | | | | | Merge some duplicate code. | |||||
| * | decoder/faad: remove unnecessary read | Max Kellermann | 2014-07-12 | 1 | -2/+0 | |
| | | | | | | | | Eliminate some overhead when the caller doesn't need the buffer. | |||||
| * | DecoderBuffer: add "pure" attributes | Max Kellermann | 2014-07-12 | 1 | -0/+4 | |
| | | ||||||
| * | DecoderBuffer: add method _clear() | Max Kellermann | 2014-07-12 | 3 | -8/+12 | |
| | | ||||||
| * | decoder/faad: check sample_rate, not frames_per_second | Max Kellermann | 2014-07-11 | 1 | -2/+4 | |
| | | | | | | | | Checking the integer is faster, easier and more reliable. | |||||
| * | decoder/faad: make variables more local | Max Kellermann | 2014-07-11 | 1 | -71/+49 | |
| | | ||||||
| * | decoder/faad: use MAX_CHANNELS | Max Kellermann | 2014-07-11 | 1 | -4/+2 | |
| | | | | | | | | .. instead of declaring a new constant. | |||||
* | | decoder/sndfile: implement scan_stream() instead of scan_file() | Max Kellermann | 2014-07-11 | 1 | -5/+6 | |
| | | ||||||
* | | decoder/sndfile: make variables more local | Max Kellermann | 2014-07-11 | 1 | -10/+7 | |
| | | ||||||
* | | decoder/sndfile: support more tag types | Max Kellermann | 2014-07-11 | 1 | -0/+4 | |
| | | ||||||
* | | decoder/sndfile: add str_type to TagType table | Max Kellermann | 2014-07-11 | 1 | -3/+11 | |
| | | ||||||
* | | decoder/sndfile: move code to sndfile_handle_tag() | Max Kellermann | 2014-07-11 | 1 | -15/+12 | |
| | | ||||||
* | | decoder/sndfile: log libsndfile version on startup | Max Kellermann | 2014-07-11 | 1 | -1/+8 | |
| | | ||||||
* | | PlaylistEdit: fix typo in code comment | Max Kellermann | 2014-07-11 | 1 | -1/+1 | |
| | | ||||||
* | | Merge branch 'v0.18.x' | Max Kellermann | 2014-07-11 | 10 | -33/+144 | |
|\| | ||||||
| * | decoder/sndfile: use decoder_read_full() | Max Kellermann | 2014-07-11 | 1 | -16/+6 | |
| | | | | | | | | | | Replaces the loop in sndfile_vio_read(), eliminating duplicate and fragile code. | |||||
| * | decoder/sndfile: use decoder_read() | Max Kellermann | 2014-07-11 | 1 | -16/+22 | |
| | | | | | | | | .. instead of InputStream::LockRead(). The former is cancellable. | |||||
| * | decoder/sndfile: log seek errors | Max Kellermann | 2014-07-11 | 1 | -1/+4 | |
| | | ||||||
| * | decoder/audiofile: log seek errors | Max Kellermann | 2014-07-11 | 1 | -0/+1 | |
| | | ||||||
| * | decoder/audiofile: fix typo in comment | Max Kellermann | 2014-07-11 | 1 | -1/+1 | |
| | | ||||||
| * | PlaylistEdit: postpone UpdateQueuedSong() when adding multiple songs | Max Kellermann | 2014-07-11 | 7 | -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 local | Max Kellermann | 2014-07-11 | 1 | -3/+2 | |
| | | ||||||
| * | Playlist: randomize next song when enabling "random" mode while not playing | Max Kellermann | 2014-07-11 | 1 | -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 comment | Max Kellermann | 2014-07-11 | 1 | -1/+1 | |
| | | ||||||
* | | input/curl: options "verify_peer" and "verify_host" | Max Kellermann | 2014-07-11 | 1 | -0/+8 | |
| | |