Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
* | | Merge branch 'v0.16.x' | Max Kellermann | 2012-02-13 | 5 | -6/+17 | |
|\| | | | | | | | | | | | | | | | Conflicts: NEWS configure.ac src/decoder/ffmpeg_decoder_plugin.c test/read_tags.c | |||||
| * | decoder/ffmpeg: read the "year" tag | Max Kellermann | 2012-02-13 | 1 | -1/+1 | |
| | | | | | | | | | | | | This was disabled when compiled with a new ffmpeg version. Older ffmpeg versions used it explicitly, while newer ones may pass it through from the codec. | |||||
| * | decoder_api: check state before emitting initial seek command | Max Kellermann | 2012-02-13 | 1 | -0/+6 | |
| | | | | | | | | This fixes seeking in the vorbis decoder during MPD startup. | |||||
| * | pcm_buffer: pcm_buffer_get() never returns NULL | Max Kellermann | 2012-02-13 | 2 | -0/+9 | |
| | | | | | | | | | | | | This fixes a bug when libsamplerate returns an empty buffer for a very small input buffer. The caller thinks this is an error, bug there is no GError object. | |||||
| * | output/winmm: remove pointless NULL check | Max Kellermann | 2012-02-13 | 1 | -5/+1 | |
| | | | | | | | | pcm_buffer_get() cannot ever return NULL. | |||||
* | | directory: fix reverse order of child directories | treblid | 2012-02-13 | 1 | -1/+1 | |
| | | | | | | | | | | Directories are loaded in reverse order when MPD starts. Only fixed when doing a rescan. | |||||
* | | playlist/flac: delete this obsolete plugin | Max Kellermann | 2012-02-12 | 3 | -200/+0 | |
| | | | | | | | | | | The FLAC playlist plugin has been superseded by the "embcue" playlist plugin, which can read the embedded CUE sheets of all formats. | |||||
* | | playlist/embcue: ignore "FILE", always point to container song file | Max Kellermann | 2012-02-12 | 1 | -2/+15 | |
| | | | | | | | | | | An embedded CUE sheet must always point to the song file it is contained in. | |||||
* | | song: add function song_replace_uri() | Max Kellermann | 2012-02-12 | 2 | -0/+21 | |
| | | ||||||
* | | db_print: print extra "playlist" object for embedded CUE sheets | Max Kellermann | 2012-02-12 | 1 | -12/+30 | |
| | | | | | | | | | | | | This finally enables the new embedded CUE sheet code: when a song file contains a playlist, it is printed in the "lsinfo" output, so clients get to know about this. | |||||
* | | song_update: update the "has_playlist" flag | Max Kellermann | 2012-02-12 | 1 | -3/+3 | |
| | | ||||||
* | | tag_handler: add new handler that updates has_playlist | Max Kellermann | 2012-02-12 | 2 | -0/+24 | |
| | | ||||||
* | | tag: add attribute "has_playlist" | Max Kellermann | 2012-02-12 | 4 | -0/+18 | |
| | | ||||||
* | | tag_{ape,id3}: remove the _load() functions | Max Kellermann | 2012-02-12 | 5 | -84/+6 | |
| | | | | | | | | Use _scan() instead, to have more control. | |||||
* | | playlist_vector: use the list_head library | Max Kellermann | 2012-02-12 | 9 | -80/+57 | |
| | | ||||||
* | | update_remove: add header update_remove.h | Max Kellermann | 2012-02-12 | 5 | -16/+44 | |
| | | ||||||
* | | update_walk: move code to update_db.c | Max Kellermann | 2012-02-12 | 3 | -85/+159 | |
| | | ||||||
* | | update_walk: move code to update_io.c | Max Kellermann | 2012-02-12 | 3 | -100/+168 | |
| | | ||||||
* | | update_walk: move code to update_song_file() | Max Kellermann | 2012-02-12 | 1 | -59/+64 | |
| | | ||||||
* | | playlist/embcue: new plugin for reading embedded cue sheets | Max Kellermann | 2012-02-12 | 5 | -0/+322 | |
| | | | | | | | | | | Parses CUE data from the "CUESHEET" tag. Needs further integration in the update thread. | |||||
* | | decoder/wavpack: bigger tag value buffer | Max Kellermann | 2012-02-12 | 1 | -2/+1 | |
| | | | | | | | | Prepare for big CUESHEET tags. | |||||
* | | tag_handler: handle arbitrary name/value pairs | Max Kellermann | 2012-02-12 | 8 | -8/+106 | |
| | | | | | | | | | | The new method pair() receives an arbitrary name/value pair. Support for this is being added to a few decoder plugins. | |||||
* | | decoder/wavpack: move code to wavpack_scan_tag_item() | Max Kellermann | 2012-02-11 | 1 | -26/+17 | |
| | | | | | | | | | | Remove clutter from wavpack_scan_file(), and use a (large) fixed buffer for the tag item. | |||||
* | | decoder/wavpack: use the tag_table library | Max Kellermann | 2012-02-11 | 1 | -8/+7 | |
| | | ||||||
* | | decoder/{mikmod,fluidsynth,mp4ff}: adapt to tag_handler API | Max Kellermann | 2012-02-11 | 3 | -26/+28 | |
| | | | | | | | | Fixes build regression. | |||||
* | | decoder_plugin: scan tags with callback table | Max Kellermann | 2012-02-11 | 30 | -297/+613 | |
| | | | | | | | | | | Pass a callback table to scan_file() and scan_stream(), instead of returning a tag object. | |||||
* | | decoder/gme: convert runtime check to assertion | Max Kellermann | 2012-02-11 | 1 | -21/+22 | |
| | | | | | | | | | | When gme_track_info() returns with success, then the gme_info_t pointer must be set. | |||||
* | | decoder/ffmpeg: use the tag_table library | Max Kellermann | 2012-02-11 | 1 | -13/+9 | |
| | | ||||||
* | | decoder/ffmpeg: move code to ffmpeg_metadata.c | Max Kellermann | 2012-02-11 | 3 | -46/+106 | |
| | | ||||||
* | | decoder/ffmpeg: remove AV_VERSION_INT definition | Max Kellermann | 2012-02-11 | 1 | -5/+0 | |
| | | | | | | | | All supported ffmpeg/libav versions have this. | |||||
* | | decoder/flac: check for errors only after _process_single() | Max Kellermann | 2012-02-11 | 1 | -8/+6 | |
| | | | | | | | | The only other libFLAC call (seek) does not produce fatal errors. | |||||
* | | decoder/flac: symmetric FLAC__stream_decoder_finish() calls | Max Kellermann | 2012-02-11 | 1 | -1/+3 | |
| | | | | | | | | | | Call it in the function that also invokved FLAC__stream_decoder_init_*(). | |||||
* | | decoder/flac: use error messages from libFLAC | Max Kellermann | 2012-02-11 | 3 | -44/+10 | |
| | | ||||||
* | | decoder/flac: eliminate the remaining "gotos" | Max Kellermann | 2012-02-11 | 1 | -42/+54 | |
| | | | | | | | | https://www.xkcd.com/292/ | |||||
* | | decoder/{vorbis,flac}: use the tag_table library | Max Kellermann | 2012-02-11 | 2 | -21/+21 | |
| | | ||||||
* | | tag_id3: use the tag_table library for TXXX | Max Kellermann | 2012-02-11 | 2 | -15/+26 | |
| | | ||||||
* | | tag_table: convert to a struct | Max Kellermann | 2012-02-11 | 3 | -14/+22 | |
| | | | | | | | | | | The struct is smaller because it is sparse. Its traversal is also more efficient. | |||||
* | | decoder_api: correct decoder_seek_error() documentation | Max Kellermann | 2012-02-11 | 1 | -1/+1 | |
| | | ||||||
* | | decoder/vorbis: move code to vorbis_comment.c | Max Kellermann | 2012-02-11 | 3 | -103/+167 | |
| | | ||||||
* | | cue_parser: new line based CUE sheet parser | Max Kellermann | 2012-02-10 | 6 | -330/+413 | |
| | | | | | | | | To replace libcue, the unmaintained and crashy library. | |||||
* | | command: add optional range parameter to "load" | Max Kellermann | 2012-02-09 | 1 | -4/+13 | |
| | | ||||||
* | | playlist_save: add start/end_index parameters | Max Kellermann | 2012-02-09 | 3 | -4/+12 | |
| | | ||||||
* | | playlist_queue: add start/end_index parameters | Max Kellermann | 2012-02-09 | 3 | -3/+21 | |
| | | ||||||
* | | Merge branch 'v0.16.x' | Max Kellermann | 2012-02-04 | 1 | -34/+36 | |
|\| | | | | | | | | | | | | | Conflicts: src/decoder/ffmpeg_decoder_plugin.c test/read_tags.c test/run_decoder.c | |||||
| * | decoder/ffmpeg: use AV_SAMPLE_FMT_* if available | Max Kellermann | 2012-02-03 | 1 | -0/+8 | |
| | | | | | | | | | | Implements support for libavcodec 0.9, which removes the compatibility macros SAMPLE_FMT_* | |||||
| * | decoder/ffmpeg: use sentinel for the ffmpeg_tag_maps table | Max Kellermann | 2012-02-03 | 1 | -3/+6 | |
| | | | | | | | | Minor optimisation. | |||||
| * | decoder/ffmpeg: support all MPD tags | Max Kellermann | 2012-02-03 | 1 | -12/+5 | |
| | | | | | | | | | | Use the tag_item_names table to look up the names of all MPD tags, and remove the duplicate entries from ffmpeg_tag_maps. | |||||
| * | decoder/ffmpeg: pass tag_type and name to _copy_metadata() | Max Kellermann | 2012-02-03 | 1 | -5/+6 | |
| | | | | | | | | Allow using this function without the ffmpeg_tag_map struct. | |||||
| * | decoder/ffmpeg: merge code to _copy_dictionary() | Max Kellermann | 2012-02-03 | 1 | -6/+11 | |
| | | | | | | | | Eliminate some duplicate code. | |||||
| * | decoder/ffmpeg: add macros emulating AVDictionary | Max Kellermann | 2012-02-03 | 1 | -13/+7 | |
| | | | | | | | | Move the #ifdefs out of _copy_metadata(). |