Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | 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 | 2 | -2/+5 |
| | | | | | 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. | ||||
* | decoder/vorbis: move code to vorbis_open_stream() | Max Kellermann | 2010-05-31 | 1 | -19/+23 |
| | |||||
* | decoder/vorbis: use single global ov_callbacks constant | Max Kellermann | 2010-05-30 | 1 | -6/+9 |
| | | | | Initialize the ov_callbacks struct at compile time. | ||||
* | decoder/vorbis: rename struct vorbis_decoder_data to vorbis_is | Max Kellermann | 2010-05-30 | 1 | -20/+19 |
| | |||||
* | inotify_update: follow symlinks | Max Kellermann | 2010-05-30 | 1 | -2/+1 |
| | | | | | | This is probably unsafe, and doesn't protect against symlink loops, but we will eventually add this when we bring update*.c and inotify*.c closer together. | ||||
* | inotify_update: fix assertion failure when music dir is deleted | Max Kellermann | 2010-05-30 | 1 | -1/+7 |
| | | | | | | | | This shouldn't really happen, but insane users might delete/rename the music directory while MPD runs. What was even more insane was that MPD crashed due to this. This is a workaround - there is currently nothing useful we can do in this case; except maybe poll for the music directory to reappear, but that's too much trouble for a user error. | ||||
* | test: added debug program "run_inotify" | Max Kellermann | 2010-05-30 | 2 | -0/+102 |
| | |||||
* | decoder/mp4ff: support tags "albumartist", "band" | Max Kellermann | 2010-05-30 | 2 | -0/+3 |
| | | | | | I'm not sure if mapping "band" to TAG_PERFORMER is correct, but it might be better than nothing. | ||||
* | decoder/mp4ff: use tag_table.h to parse tag names | Max Kellermann | 2010-05-30 | 1 | -18/+15 |
| | | | | Convert if/else/else/... to a loop. | ||||
* | decoder/mp4ff: rename plugin "mp4" to "mp4ff" | Max Kellermann | 2010-05-30 | 2 | -1/+2 |
| | | | | | The underlying library is named "libmp4ff". To reduce confusion, rename the plugin to a more specific name. | ||||
* | tag_ape: move table lookup to tag_table.h | Max Kellermann | 2010-05-30 | 3 | -9/+53 |
| | | | | Allow code sharing. | ||||
* | tag_ape: support album artist, MusicBrainz tags | Max Kellermann | 2010-05-30 | 2 | -1/+9 |
| | | | | | | | | | | I took these tag names from a MusePack sample file I got from a user. These are not documented in the APE specification: http://wiki.hydrogenaudio.org/index.php?title=APE_key People seem to be using undocumented extensions to the specification anyway, and the best we can do is attempt to support them. | ||||
* | Merge release 0.15.10 from branch 'v0.15.x' | Max Kellermann | 2010-05-30 | 3 | -5/+36 |
|\ | | | | | | | | | | | | | Conflicts: NEWS configure.ac src/input/mms_input_plugin.c | ||||
| * | mpd version 0.15.10release-0.15.10 | Avuton Olrich | 2010-05-30 | 2 | -2/+2 |
| | | |||||
| * | decoder/mad: fix buffer variable name on !HAVE_ID3TAG | Max Kellermann | 2010-05-30 | 1 | -3/+3 |
| | | |||||
| * | input/mms: initialize the "eof" attribute | Max Kellermann | 2010-05-18 | 2 | -0/+3 |
| | | |||||
| * | input/mms: fix memory leak in error handler | Max Kellermann | 2010-05-18 | 2 | -0/+3 |
| | | |||||
| * | decoder/mad: properly calculate ID3 size without libid3tag | Max Kellermann | 2010-04-13 | 2 | -5/+27 |
| | | | | | | | | | | | | | | | | | | | | Without libid3tag, we were trying to skip the ID3 frame (since 0.15.2). Its length however was not calculated at all, we were just dropping everything from the current input buffer. This lead to the first few seconds of the file being skipped. This patch attempts to calculate the ID3v2 frame size with the formula from: http://www.id3.org/id3v2.4.0-structure 3.1 and 6.2 | ||||
| * | Modify version string to post-release version 0.15.10~git | Avuton Olrich | 2010-03-21 | 2 | -1/+4 |
| | | |||||
* | | filter/replay_gain: added option "replaygain_limit" | Daniel Seuthe | 2010-05-30 | 8 | -14/+26 |
| | | |||||
* | | configure: Surround statements with brackets to prevent being treated as args. | Avuton Olrich | 2010-05-26 | 1 | -1/+1 |
| | | |||||
* | | configure.ac: Add sqlite results to the pretty print. | Avuton Olrich | 2010-05-25 | 1 | -0/+1 |
| | | |||||
* | | cmdline: Add default config paths for win32. | Avuton Olrich | 2010-05-20 | 1 | -1/+38 |
| | | |||||
* | | output/win32: new output plugin for Windows Wave | Max Kellermann | 2010-05-20 | 5 | -0/+323 |
| | | |||||
* | | pcm_buffer: 8 kB alignment instead of 64 kB | Max Kellermann | 2010-05-20 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | Reduce the overhead. Most buffers used by MPD are around 2 to 4 kB. 8 kB seems large enough to keep heap fragmentation low. Additionally, this patch fixes an off-by-one error in the alignment formula. | ||||
* | | test: enable binary mode on stdin/stdout | Max Kellermann | 2010-05-20 | 9 | -0/+37 |
| | | | | | | | | | | Declaring the global variable _CRT_fmode is a documented hack. What an ugly platform! | ||||
* | | tag_{id3,ape}: explicitly open files in binary mode | Max Kellermann | 2010-05-20 | 2 | -2/+2 |
| | | | | | | | | Add the flag "b" to fopen(). Windows compatibility. |