Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | decoder/ffmpeg: fix libavformat 0.6 by using av_open_input_stream() | Max Kellermann | 2010-07-19 | 1 | -89/+65 |
| | | | | | | | | | | | | libavformat 0.6 does not pass the original URI pointer to the "open" method, which leads to a crash because MPD was using a dirty hack to pass a pointer to that method. This patch switches to av_open_input_stream() with a custom ByteIOContext class, instead of doing the URI string hack with av_open_input_file(). Loosely based on a patch from Jasper St. Pierre. | ||||
* | decoder/ffmpeg: manual format probing | Max Kellermann | 2010-07-19 | 1 | -2/+47 |
| | | | | | | | | | Use the libavformat function av_probe_input_format() to probe the AVInputFormat, instead of letting av_open_input_file() do it implicitly. We will switch to av_open_input_stream() very soon, which does not have the probing code. Loosely based on a patch from Jasper St. Pierre. | ||||
* | ffmpeg: read the audio stream metadata in addition to global | Anton Khirnov | 2010-07-12 | 1 | -1/+5 |
| | | | | in some formats, e.g. vorbis, the metadata is stored per-stream. | ||||
* | ffmpeg: factor tag_type <-> ffmpeg tag name maps into a table. | Anton Khirnov | 2010-07-12 | 1 | -21/+32 |
| | |||||
* | pcm_buffer: make the buffer pointer "void" | Max Kellermann | 2010-06-30 | 1 | -1/+1 |
| | |||||
* | decoder/mp4ff: support tag "album artist" | Max Kellermann | 2010-06-25 | 1 | -0/+1 |
| | | | | | We already supported "albumartist", but it seems some folks also use "album artist" (with a space). | ||||
* | playlist_print: use playlist_open_any() | Max Kellermann | 2010-06-25 | 1 | -2/+2 |
| | | | | | Allow printing remote playlists with the commands "listplaylist" and "listplaylistinfo". | ||||
* | playlist_queue: use playlist_open_any() | Max Kellermann | 2010-06-25 | 1 | -48/+2 |
| | |||||
* | playlist_any: new library to simplify opening playlist files | Max Kellermann | 2010-06-25 | 2 | -0/+108 |
| | | | | | | The new function playlist_open_any() combines playlist_mapper_open(), playlist_list_open_uri() and playlist_list_open_stream(), providing an easy API for all of them. | ||||
* | playlist_list: probe plugin without MIME attributes | Max Kellermann | 2010-06-25 | 1 | -3/+23 |
| | | | | | If the MIME type of a stream contains a semicolon, remove it and the text after it to probe for a playlist plugin. | ||||
* | playlist_queue: simplify error handler | Max Kellermann | 2010-06-25 | 1 | -9/+8 |
| | | | | Return early on error, save one level of indent. | ||||
* | playlist_list: moved input_stream.ready loop to calling function | Max Kellermann | 2010-06-25 | 1 | -22/+11 |
| | | | | | | Merged both loops into playlist_list_open_stream(). This is needed because playlist_list_open_stream() needs to know the MIME type, which is only known after the stream has become "ready". | ||||
* | uri: really count dots in verify_uri_segment() | Max Kellermann | 2010-06-25 | 1 | -1/+4 |
| | | | | | | This buggy implementation failed to allow "..." sequences, because the dot count was always zero. The usefulness of allowing "..." (or more dots) is debatable, but since it's a valid file name, we allow it. | ||||
* | playlist/cue: last track ends at end of file | Max Kellermann | 2010-06-25 | 1 | -3/+2 |
| | | | | | | | | libcue's track_get_length() returns 0 for the last track, because that information is not available in the CUE sheet. This makes MPD quit playing the last track immediately. If we set "song.end_ms=0", MPD will play the track until the end of the song file, which is what we want. | ||||
* | song_print: simplified start_ms/end_ms check | Max Kellermann | 2010-06-25 | 1 | -12/+10 |
| | |||||
* | playlist_list: wait for input stream to become ready | Aaron Griffith | 2010-06-25 | 1 | -0/+22 |
| | | | | Fixes an assertion failure in the input_stream_seek() call. | ||||
* | Make get_remote_uid() work on BSD | Andreas Vögele | 2010-06-19 | 1 | -1/+7 |
| | | | | | | I've attached a patch that will make file URIs work on operating systems that provide the getpeereid() function call to check the user ID of the peer connected to a UNIX domain socket. | ||||
* | client: increase send_buf from 4kB to 16kB | Andrzej Rybczak | 2010-06-19 | 1 | -1/+1 |
| | | | | | | this greatly improves performance of commands that return a lot of data, e.g. search results or recursive content of a directory, while being connected to local mpd via tcp/ip socket. | ||||
* | playlist: check "queued" before calling playlist_update_queued_song() | Max Kellermann | 2010-06-19 | 1 | -1/+1 |
| | | | | Workaround for an assertion failure. | ||||
* | playlist: protect acess to player state in playlist_sync() | Max Kellermann | 2010-06-19 | 1 | -2/+7 |
| | |||||
* | playlist: move checks out of playlist_sync_with_queue() | Max Kellermann | 2010-06-19 | 1 | -20/+21 |
| | | | | | Rename the function to playlist_song_started(), which gets only called if the song has actually started. | ||||
* | player_control: hold mutex in pc_play(), pc_pause() | Max Kellermann | 2010-06-19 | 1 | -9/+42 |
| | | | | Race condition fix. | ||||
* | filter/route: fixed unsigned/signed comparison | Max Kellermann | 2010-06-06 | 1 | -1/+1 |
| | | | | Fixes a clang warning. | ||||
* | output/httpd: add libwrap support | Tim Phipps | 2010-06-06 | 1 | -0/+28 |
| | | | | | | libwrap support is in MPD but only for the control port. This patch adds support for the http port. The code is copied from src/client_new.c | ||||
* | directory_print: print a list of playlist files in "lsinfo" | Max Kellermann | 2010-06-01 | 1 | -0/+61 |
| | | | | Print those files which can be handled by a playlist plugin. | ||||
* | playlist_list: export playlist_suffix_supported() | Max Kellermann | 2010-06-01 | 2 | -1/+10 |
| | |||||
* | playlist_list: playlist_list_open_path() returns input_stream | Max Kellermann | 2010-06-01 | 6 | -16/+39 |
| | | | | | | | Memory leak fix. The input_stream object passed to playlist_list_open_stream_suffix() must be closed by the caller - this however never happens in playlist_list_open_path(), because it does not return it to the caller. | ||||
* | playlist_list: move fallback g_uri_parse_scheme() to glib_compat.h | Max Kellermann | 2010-06-01 | 2 | -14/+16 |
| | |||||
* | playlist: emit IDLE_OPTIONS when resetting single mode | Max Kellermann | 2010-06-01 | 1 | -0/+2 |
| | |||||
* | single mode: at the end of the song, pause on the next song instead of stop | Romain Bignon | 2010-05-31 | 3 | -19/+13 |
| | |||||
* | directory_print: return void | Max Kellermann | 2010-05-31 | 2 | -7/+3 |
| | | | | There is no useful return value here. | ||||
* | fix crash when decoder is NULL | Romain Bignon | 2010-05-31 | 1 | -2/+2 |
| | |||||
* | decoder/mikmod: fix memory leak | Max Kellermann | 2010-05-31 | 1 | -2/+4 |
| | | | | | The return value of Player_LoadTitle() is allocated with malloc(), and must be freed by the caller. | ||||
* | decoder/mikmod: duplicate the path only once | Max Kellermann | 2010-05-31 | 1 | -2/+2 |
| | |||||
* | decoder/mikdmod: moved local variable declarations in tag_dup() | Max Kellermann | 2010-05-31 | 1 | -12/+8 |
| | |||||
* | decoder/wildmidi: moved local variable declarations in tag_dup() | Max Kellermann | 2010-05-31 | 1 | -7/+3 |
| | |||||
* | decoder/gme: replace macro GME_BUF_SIZE | Max Kellermann | 2010-05-31 | 1 | -4/+5 |
| | | | | | Added macros with better names: GME_BUFFER_FRAMES, GME_BUFFER_SAMPLES (the former only used to calculate the latter). | ||||
* | decoder/gme: added constants for sample rate and channels | Max Kellermann | 2010-05-31 | 1 | -6/+12 |
| | | | | Move into enums. | ||||
* | decoder/gme: pass the whole buffer to decoder_data() | Max Kellermann | 2010-05-31 | 1 | -2/+2 |
| | | | | | | | | Pass sizeof(buf) to decoder_data(), not the number of samples (which is half the size). At the same time, pass GME_BUF_SIZE to gme_play() - libgme really wants to get the number of samples, not the number of stereo frames. Previously, this plugin had been using only the first half of the buffer. | ||||
* | decoder/gme: allocate tag later, fixes memory leak | Max Kellermann | 2010-05-31 | 1 | -1/+1 |
| | | | | Allocate the "tag" object after the file has been opened successfully. | ||||
* | decoder/mp4ff: rename and move local variable | Max Kellermann | 2010-05-31 | 1 | -6/+5 |
| | | | | | Allocate the "tag" object after the file has been checked. That removes one tag_free() call in an error handler. | ||||
* | decoder/mp4ff: merge code into mp4ff_input_stream_open() | Max Kellermann | 2010-05-31 | 1 | -17/+17 |
| | |||||
* | decoder/mp4ff: move mp4ff_callback_t into mp4ff_input_stream | Max Kellermann | 2010-05-31 | 1 | -12/+15 |
| | | | | Allocate only one item on the stack. | ||||
* | decoder/mp4ff: rename mp4_context to mp4ff_input_stream | Max Kellermann | 2010-05-31 | 1 | -9/+9 |
| | |||||
* | decoder/mp4ff: remove duplicate entries in the tag name table | Max Kellermann | 2010-05-31 | 1 | -9/+5 |
| | | | | Reuse the function tag_name_parse_i(). | ||||
* | decoder/mp4ff: moved code to mp4ff_tag_name_parse() | Max Kellermann | 2010-05-31 | 1 | -1/+7 |
| | |||||
* | tag_ape: remove duplicate entries in the tag name table | Max Kellermann | 2010-05-31 | 1 | -13/+5 |
| | | | | Reuse the function tag_name_parse_i(). | ||||
* | tag_ape: move code to tag_ape_name_parse() | Max Kellermann | 2010-05-31 | 1 | -1/+7 |
| | |||||
* | decoder/vorbis: rename local variable "ret" | Max Kellermann | 2010-05-31 | 1 | -6/+5 |
| | |||||
* | decoder/vorbis: implement method stream_tag() | Max Kellermann | 2010-05-31 | 1 | -11/+4 |
| | | | | This allows tags in archive files. |