aboutsummaryrefslogtreecommitdiffstats
path: root/src (follow)
Commit message (Collapse)AuthorAgeFilesLines
* string_util: add function strchug_fast()Max Kellermann2010-12-237-10/+64
| | | | Replace g_strchug() calls with a cheaper implementation.
* utils: move string_array_contains() to string_util.cMax Kellermann2010-12-238-27/+78
|
* decoder: new "pcm" decoder pluginMax Kellermann2010-12-223-0/+119
| | | | Just there to support the "cdio_paranoia" input plugin.
* configure.ac: hook the cdio_paranoia input pluginMax Kellermann2010-12-222-0/+10
|
* input/cdda: rename plugin to "cdio_paranoia"Max Kellermann2010-12-222-42/+42
|
* input/cdda: support reading the whole discMax Kellermann2010-12-221-10/+8
|
* input/cdda: remove unused function input_cdda_archive_extract_trackno()Max Kellermann2010-12-221-24/+0
|
* input/cdda: import missing pcm16_to_wave() from the wave encoderMax Kellermann2010-12-221-0/+11
|
* input/cdda: implement parse_cdda_uri()Max Kellermann2010-12-221-10/+59
| | | | Was missing.
* input/cdda: call input_cdda_close() with an input_stream pointerMax Kellermann2010-12-221-5/+5
| | | | Another build fix.
* input/cdda: move code to cdda_detect_drive()Max Kellermann2010-12-221-7/+18
|
* input/cdda: remove newlines from error messagesMax Kellermann2010-12-221-8/+10
|
* input/cdda: remove debug codeMax Kellermann2010-12-221-31/+1
|
* input/cdda: some general build failure fixesMax Kellermann2010-12-221-13/+5
|
* input_cdda_plugin: new plugin to handle cdda:// protocol to access CD-DA ↵Viliam Mateicka2010-12-222-0/+406
| | | | audio CD's
* osx_output: always pass OS X result code to g_set_error().Greg Ward2010-12-211-9/+9
| | | | | | | | | Should be safe on OS X 10.4 (32-bit), since Apple's OSStatus boils down to "signed long", and g_set_error() takes gint, which is really just "int". Assigning "signed long" to "int" on 32-bit Unix should be just fine, since both are signed 32-bit ints. No idea if this is safe on 64-bit OS X.
* osx_output: allow user to specify other audio devices.Greg Ward2010-12-211-1/+119
| | | | | | | | | Add new config parameter 'device' to audio_output type "osx": - if not supplied or set to "default", open default device - if set to "system", open system device - otherwise 'device' should be an audio device name: mpd will find and open the specified audio device, falling back to the default device if it's not found
* tag_id3: support multiple valuesMax Kellermann2010-12-071-10/+36
| | | | | Loop over all frames with a specific id, and import all of them - not just the first one (index 0).
* command: don't error when sticker list is run on song with no stickersAnton Khirnov2010-12-071-7/+3
| | | | | | this is inconsistent with other commands (e.g. find) and seems wrong -- a song with no stickers attached is a perfectly valid state and an empty list of stickers is also perfectly valid.
* tag_ape: support multiple valuesMax Kellermann2010-11-241-1/+15
| | | | One APE tag may contain more than one value, separated by null bytes.
* decoder_thread: load APE replay gain from music filesMax Kellermann2010-11-181-0/+15
|
* replay_gain_ape: parse replay gain from APE tagsMax Kellermann2010-11-182-0/+110
| | | | Based on the APE reader.
* tag_ape: move code to ape.cMax Kellermann2010-11-183-93/+174
| | | | Generic library for scanning APE tags. Eliminated one "goto"!
* timer: fix integer overflow in timer_delay()Max Kellermann2010-11-181-1/+1
| | | | | | | Fixes a regression: for output_plugin.delay(), we added a method to the timer class which returns the delay in milliseconds. This fails to detect negative values, because the unsigned integer is divided by 1000, and then casted to signed.
* playlist_song: calculate duration of last CUE trackMax Kellermann2010-11-081-0/+8
|
* Merge release 0.15.15 from branch 'v0.15.x'Max Kellermann2010-11-082-2/+2
|\ | | | | | | | | | | Conflicts: NEWS configure.ac
| * output/shout: artist comes first in stream titleMax Kellermann2010-11-081-1/+1
| | | | | | | | | | | | After popular demand, I've switched the order of "artist" and "title" in the stream title. There is no standard, and there is no reliable way to parse those from the stream title.
| * input/rewind: fix assertion failureMax Kellermann2010-11-081-1/+1
| | | | | | | | | | The assertion added in MPD 0.15.14 was too much, it failed when the MIME type of a stream was NULL.
* | update_walk: explicitly check for permission problemsMax Kellermann2010-11-081-0/+33
| | | | | | | | | | | | Call access() and print an extra error message when EACCES is returned. Hopefully this will reduce the number of support requests due to wrong file permissions.
* | Merge release 0.15.14 from branch 'v0.15.x'Max Kellermann2010-11-0710-45/+100
|\| | | | | | | | | | | | | | | | | | | | | | | Conflicts: NEWS configure.ac src/decoder_control.c src/decoder_control.h src/input/rewind_input_plugin.c src/output_control.c src/output_thread.c src/player_thread.c
| * player_thread: fix assertion failure due to wrong music pipe on seekMax Kellermann2010-11-051-0/+8
| | | | | | | | | | | | | | | | | | When one song is played twice, and the decoder is working on the second "instance", but the first should be seeked, the check in player_seek_decoder() may assume that it can reuse the decoder without exchanging pipes. The last thing was the mistake: the pipe pointer was different, which led to an assertion failure. This patch adds another check which exchanges the player pipe.
| * decoder_control: pass music_pipe to dc_start()Max Kellermann2010-11-053-12/+18
| | | | | | | | More abstraction for decoder_control.pipe.
| * player_thread: add helper function player_dc_at_next_song()Max Kellermann2010-11-051-6/+33
| | | | | | | | Some abstraction for decoder_control.pipe access.
| * pipe: add helper function music_pipe_empty()Max Kellermann2010-11-053-4/+10
| |
| * input/rewind: remove redundant NULL check before g_free() callMax Kellermann2010-11-051-2/+1
| |
| * input/rewind: add two assertionsMax Kellermann2010-11-051-0/+3
| |
| * input/rewind: fix double free bugMax Kellermann2010-11-051-0/+1
| | | | | | | | | | Duplicate the "mime" attribute of the inner input_stream object, instead of copying the pointer.
| * decoder/{mp4ff,ffmpeg}: add extension ".m4b" (audio book)Max Kellermann2010-11-052-2/+10
| | | | | | | | Same as ".m4a".
| * output_thread: fix assertion failure due to race condition in OPENMax Kellermann2010-11-041-1/+9
| | | | | | | | | | | | Change the assertion on "fail_timer==NULL" in OPEN to a runtime check. This assertion crashed when the output thread failed while the player thread was calling audio_output_open().
| * output_internal: protect attribute "fail_timer" with mutexMax Kellermann2010-11-042-1/+7
| |
| * output_control: lock object in audio_output_open()Max Kellermann2010-11-041-6/+19
| | | | | | | | Protect the attributes "open" and "fail_timer".
| * output_control: lock object in audio_output_close()Max Kellermann2010-11-041-2/+28
| | | | | | | | Protect the attributes "open" and "fail_timer".
* | output/alsa: dump buffer and period limitsMax Kellermann2010-11-051-0/+20
| |
* | output/httpd: implement delay()Max Kellermann2010-11-051-2/+11
| |
* | output/shout: implement delay()Max Kellermann2010-11-051-8/+13
| | | | | | | | | | This makes the plugin more responsive to control commands, because it will listen to control events while waiting.
* | output_plugin: add method delay()Max Kellermann2010-11-053-3/+51
| | | | | | | | | | This method is used to reduce the delay of commands issued to the shout plugin.
* | timer: add function timer_delay()Max Kellermann2010-11-052-0/+19
| |
* | server_socket: remove AI_ADDRCONFIGMantas Mikulenas2010-11-041-3/+0
| | | | | | | | | | | | | | When you pass the flag AI_ADDRCONFIG to getaddrinfo(), it does not consider address families on the loopback device. When run on a machine without an external network card, just with "lo", it was unable to look up any address.
* | output/ffado: transfer_playback_buffers() returns a booleanMax Kellermann2010-11-041-1/+4
| | | | | | | | | | libffado documentation says this function returns -1 on error, but that is a lie - it returns a boolean value, and "false" means error.
* | decoder/ffmpeg: check AVCodecContext.sample_fmt valueMax Kellermann2010-11-041-7/+9
| | | | | | | | | | .. instead of av_get_bits_per_sample_format(). The SampleFormat enum value is authoritative.