aboutsummaryrefslogtreecommitdiffstats
path: root/src (follow)
Commit message (Collapse)AuthorAgeFilesLines
* output/httpd: forced flush after 32 kB of input dataMax Kellermann2010-08-312-0/+23
| | | | | Avoid buffer underruns on the streaming client, if the encoder is "too efficient" (e.g. when encoding silence while paused).
* ReplayGain filter: allow gain > 100 %Johan Kiviniemi2010-08-231-3/+11
| | | | | | | The ReplayGain filter clamped the gain to max. 100 % even if the algorithm determined the signal needed a boost. That would result in any such tracks being played with too low volume, effectively defeating the purpose of the filter.
* fd_util: add function dup_cloexec()Max Kellermann2010-08-032-0/+17
| | | | | | Unfortunately, there's no "optimized" implementation here. We can't use Linux's proprietary system call dup3(), because it would require us to specify the new descriptor.
* fd_util: add function recvmsg_cloexec()Max Kellermann2010-08-032-0/+49
|
* fd_util: add function socketpair_cloexec()Max Kellermann2010-08-032-0/+35
|
* playlist_song: fix memory leakMax Kellermann2010-07-251-0/+2
| | | | Free the temporary path string in apply_song_metadata().
* directory: free playlist vector in directory_free()Max Kellermann2010-07-251-0/+2
|
* queue_save: save tags and range of non-database songsMax Kellermann2010-07-255-21/+63
| | | | | Use the functions song_save() and song_load() to use the same format as in the database file for those songs which need the tags.
* song_save: save start_ms and end_msMax Kellermann2010-07-251-0/+11
| | | | | While this is not useful for the database, it may become useful for reusing this code for the state file.
* queue_save: simplify get_song()Max Kellermann2010-07-251-10/+3
| | | | Don't try db_get_song() if the URI has a scheme.
* {queue,song}_print: print relative paths if possibleMax Kellermann2010-07-254-1/+22
| | | | | | If a song with an absolute path points inside the music directory, print only the relative part. This happens when partial songs from a playlist file were loaded.
* queue_print: hide HTTP password in the "playlist" commandMax Kellermann2010-07-251-5/+2
| | | | | | | I've already changed the "playlistinfo" command to hide HTTP passwords, but forgot to do the same for the simpler "playlist" command. This patch changes queue_print_uris() to use the code from song_print_uri().
* queue_save: move code to queue_save_song()Max Kellermann2010-07-251-7/+11
|
* queue_save: queue_load_song() returns voidMax Kellermann2010-07-253-11/+7
| | | | | The only caller doesn't use its return value, and the value isn't useful anyway.
* song_save: song_load() returns NULL instead of falseMax Kellermann2010-07-251-2/+2
|
* state_file: use the text_file libraryMax Kellermann2010-07-253-38/+42
| | | | Don't use a large stack buffer.
* playlist_state: simplify printf() callsMax Kellermann2010-07-251-22/+18
| | | | Let the C compiler concatenate string constants.
* database, ...: remove EINTR checks after stdio callsMax Kellermann2010-07-255-18/+18
| | | | | | MPD doesn't have child processes anymore, and thus we're not expecting to receive SIGCHLD very often. Since hard disk access isn't interrupted by signals anyway, we don't need those excessive checks.
* directory_save: duplicate the playlist nameMax Kellermann2010-07-251-2/+9
| | | | | | The function playlist_metadata_load() will overwrite the input buffer before using the "name" parameter; since "name" points to the same buffer, we'll get a corrupted string.
* Added album tag support for libgme decoderRasi2010-07-231-0/+2
|
* update: store playlist files in databaseMax Kellermann2010-07-219-31/+353
| | | | | Don't open the music directory for each "lsinfo" call. Get the list of playlist files from the memory database.
* song_save: pass const songvec to songvec_save()Max Kellermann2010-07-212-2/+3
|
* song_save: include cleanupMax Kellermann2010-07-211-1/+0
|
* database: remove outdated commentMax Kellermann2010-07-211-1/+0
|
* tag_rva2: move code to rva2_apply_data()Max Kellermann2010-07-201-11/+16
|
* tag_rva2: add struct rva2_dataMax Kellermann2010-07-201-18/+39
| | | | | .. and several accessor inline functions, to simplify the calling code.
* tag_rva2: name the CHANNEL_* enumMax Kellermann2010-07-201-12/+12
|
* decoder/mad: move RVA2 code to tag_rva2.cMax Kellermann2010-07-203-89/+151
|
* Merge release 0.15.12 from branch 'v0.15.x'Max Kellermann2010-07-203-13/+31
|\ | | | | | | | | | | Conflicts: NEWS configure.ac
| * input/curl: remove assertion after curl_multi_fdset()Max Kellermann2010-07-201-2/+0
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Some users reported that MPD crashes when using a new CURL version with the threaded DNS resolver enabled. It seems that curl_multi_fdset() returns no file descriptor when the DNS resolver runs in another thread, so MPD does not have any event to wait for. On the CURL mailing list, somebody suggested to sleep for a fixed amount of time. This is not an elegant solution, because daemons should never have to sleep without waiting for an event. I hope the CURL developers will review the API and remove the threaded DNS resolver. Meanwhile, I'm removing the assertion in question, to allow those unfortunate users running the latest CURL version to continue using MPD.
| * input/curl: query timeout from CURLMax Kellermann2010-07-201-1/+18
| | | | | | | | | | Use curl_multi_timeout() to determine the select() timeout, instead of hard-coding one second.
| * tag_rva2: set "gain", not "peak"Max Kellermann2010-07-201-2/+2
| | | | | | | | RVA2 tags only store the "gain" value, there is no "peak" attribute.
| * decoder/mad: parse_rva2() returns boolMax Kellermann2010-07-201-9/+8
| |
| * decoder/wildmidi: support version 0.2.3Max Kellermann2010-07-201-0/+4
| | | | | | | | | | | | | | In libwildmidi 0.2.3, the function WildMidi_SampledSeek() was removed, without changing the SO name. This patch adds an autoconf check for that function. Fall back to WildMidi_FastSeek() if WildMidi_SampledSeek() is not available anymore.
* | replay_gain_info: fix indentationMax Kellermann2010-07-201-10/+7
| |
* | Merge release 0.15.11 from branch 'v0.15.xMax Kellermann2010-07-191-0/+1
|\| | | | | | | | | | | | | | | | | | | | | | | | | Conflicts: NEWS configure.ac src/decoder/ffmpeg_decoder_plugin.c src/decoder/mikmod_decoder_plugin.c src/decoder/mp4ff_decoder_plugin.c src/decoder/vorbis_decoder_plugin.c src/directory_print.c src/playlist_control.c src/tag_ape.c
| * decoder/ffmpeg: fix libavformat 0.6 by using av_open_input_stream()Max Kellermann2010-06-301-82/+52
| | | | | | | | | | | | | | | | | | | | | | | | 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 probingMax Kellermann2010-06-301-4/+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.
| * decoder/ffmpeg: free URI, fix memory leakMax Kellermann2010-06-301-1/+3
| | | | | | | | Free the string allocated by decoder_get_uri().
| * decoder/vorbis: handle uri==NULLMax Kellermann2010-06-301-0/+3
| | | | | | | | This fixes a theoretical crash, which has never occurred in practice.
| * ffmpeg: read more metadata.Anton Khirnov2010-06-301-1/+10
| |
| * decoder/ffmpeg: free AVFormatContext on errorMax Kellermann2010-06-301-0/+4
| | | | | | | | Fix a memory leak in some code paths.
| * pcm_buffer: make the buffer pointer "void"Max Kellermann2010-06-301-1/+1
| |
| * decoder/mp4ff: support tag "album artist"Max Kellermann2010-06-301-0/+1
| | | | | | | | | | We already supported "albumartist", but it seems some folks also use "album artist" (with a space).
| * Make get_remote_uid() work on BSDAndreas Vögele2010-06-301-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.
| * playlist: emit IDLE_OPTIONS when resetting single modeMax Kellermann2010-06-301-0/+3
| |
| * directory_print: return voidMax Kellermann2010-06-302-7/+3
| | | | | | | | There is no useful return value here.
| * decoder/mikmod: fix memory leakMax Kellermann2010-06-301-2/+4
| | | | | | | | | | The return value of Player_LoadTitle() is allocated with malloc(), and must be freed by the caller.
| * decoder/mp4ff: remove duplicate entries in the tag name tableMax Kellermann2010-06-301-9/+5
| | | | | | | | Reuse the function tag_name_parse_i().
| * decoder/mp4ff: moved code to mp4ff_tag_name_parse()Max Kellermann2010-06-301-1/+7
| |