aboutsummaryrefslogtreecommitdiffstats
path: root/src (follow)
Commit message (Collapse)AuthorAgeFilesLines
* player_thread: simplified thread destructionMax Kellermann2009-10-311-4/+2
| | | | Simply use "return" instead of g_thread_exit().
* songvec: sort songs by album name first, then disc/track numberMax Kellermann2009-10-311-1/+30
| | | | | When the songs of two albums are in the same directory, all songs of an album should be right next to each others.
* songvec: simplified compare_tag_item()Max Kellermann2009-10-311-8/+10
| | | | | Moved some code to tag_get_value_checked(), to eliminate several NULL checks.
* player_control: protect command, state, error with a mutexMax Kellermann2009-10-3112-89/+263
| | | | | | Use GMutex/GCond instead of the notify library. Manually lock the player_control object before accessing the protected attributes. Use the GCond object to notify the player thread and the main thread.
* {player,output}_thread: fixed elapsed_time quirksMax Kellermann2009-10-303-3/+23
| | | | | | | | Right after seeking and song change, the elapsed_time shows old information, because the output thread didn't finish a full chunk yet. This patch re-adds a second elapsed_time variable, and keeps track of a fallback value, in case the output thread can't provide a reliable value.
* output_thread: return bool from ao_play()Max Kellermann2009-10-291-4/+22
| | | | | | Return false when there was no chunk in the pipe. If the function returns true, then audio_output_task() will not wait for a notify from the player thread. This fixes a race condition.
* player_thread: set error status in play_next_chunk()Max Kellermann2009-10-291-4/+3
| | | | | | Don't set the error in play_chunk(); do all the error handling in the caller. The errored_song attribute isn't set anymore; it doesn't make sense for PLAYER_ERROR_AUDIO.
* output_control: fixed deadlock in audio_output_update()Max Kellermann2009-10-291-1/+21
| | | | Call a version of audio_output_close() which doesn't lock recursively.
* httpd: add config option to limit number of clientsViliam Mateicka2009-10-292-3/+20
|
* output: consistently lock audio output objectsMax Kellermann2009-10-295-46/+102
| | | | | Always keep the audio_output object locked within the output thread, unless a plugin method is called. This fixes several race conditions.
* output_plugin: added method "drain"Max Kellermann2009-10-293-14/+34
| | | | | | | drain() is the opposite of cancel(): it waits until all data in the buffer has finished playing. Instead of implicitly draining in the close() method like the ALSA plugin has been doing it forever, let the output thread decide whether to drain or to cancel.
* output/alsa: don't recover on CANCELMax Kellermann2009-10-291-1/+1
| | | | | | The recovery is for nothing if we get CLOSE afterwards. Let's not recover in the cancel() method, and let the next play() call sort it out.
* output_thread: removed redundant filter_close() callMax Kellermann2009-10-291-4/+0
| | | | Don't call filter_close() right after ao_close().
* output/pulse: initialize pulse_output.mixerMax Kellermann2009-10-291-0/+1
| | | | This variable was uninitialized and led to crashes.
* decoder/ffmpeg: removed the "author" vs "artist" workaroundMax Kellermann2009-10-281-2/+1
| | | | | libavformat gives us the song artist in the "author" field. Since we use av_metadata_conv(), we don't need to check for "artist".
* include pulse/version.h for PA_CHECK_VERSIONAlam Arias2009-10-271-0/+2
|
* encoder: renaming none_encoder to null_encoderViliam Mateicka2009-10-262-27/+27
|
* mpd.conf: new bool config value for enabling/disabling inotify updateViliam Mateicka2009-10-263-2/+8
|
* encoder: new encoder plugin which just pass data throughViliam Mateicka2009-10-242-0/+126
|
* add --disable-inotify for configure to disable inotify when autodetectedViliam Mateicka2009-10-241-0/+7
|
* output/jack: implement methods enable()/disable()Max Kellermann2009-10-231-16/+24
| | | | Don't connect to JACK before MPD has daemonized.
* output/pulse: implement methods enable()/disable()Max Kellermann2009-10-231-9/+35
| | | | Don't connect to PulseAudio before MPD has daemonized.
* output_plugin: added methods enable() and disable()Max Kellermann2009-10-2315-1/+213
| | | | | | | With these methods, an output plugin can allocate some global resources only if it is actually enabled. The method enable() is called after daemonization, which allows for more sophisticated resource allocation during that method.
* output/pulse: call mixer on state changesMax Kellermann2009-10-234-129/+196
| | | | | | Don't let the mixer plugin "override" the libpulse callbacks. Instead, add a "mixer" attribute to the pulse_output struct, and call the mixer on all interesting events.
* mixer_control: don't close the mixer if set_volume() failsMax Kellermann2009-10-231-2/+0
| | | | | A mixer is useful enough if it can be read. Setting it may be found unavailable at runtime.
* mixer_plugin: get_volume() may return -1 if unavailableMax Kellermann2009-10-232-4/+8
| | | | | | If the method get_volume() returns -1 and no error object is set, then the volume is currently unavailable, but the mixer should not be closed immediately.
* mixer_control: allow methods "open" and "close" to be NULLMax Kellermann2009-10-232-20/+5
| | | | | It's possible to have a mixer implementation which does not explicitly need the methods open() and close().
* mixer/pulse: don't get volume if stream is not yet readyMax Kellermann2009-10-221-3/+3
| | | | Moved the check from pulse_mixer_open() to pulse_mixer_update().
* output/fifo: renamed source to fifo_output_plugin.cMax Kellermann2009-10-221-3/+3
|
* audio: removed function finishAudioConfig()Max Kellermann2009-10-223-8/+0
| | | | There's no point in clearing the audio format before exiting.
* main: put #ifdef inside winsock_init()Max Kellermann2009-10-221-5/+2
| | | | | This way, the function call in the main() function does not need another pair of #ifdef/#endif.
* permission: improve const-correctnessSF Markus Elfring2009-10-222-2/+2
|
* playlist: new ASX playlist pluginMax Kellermann2009-10-213-0/+340
| | | | Based on the XSPF playlist plugin.
* playlist/xspf: ignore text in root, playlist, tracklistMax Kellermann2009-10-211-0/+2
| | | | Added a missing "break".
* audio_format: wildcards allowed in audio_format configurationMax Kellermann2009-10-217-22/+92
| | | | | | An asterisk means that this attribute should not be enforced, and stays whatever it used to be. This way, some configuration values work like masks.
* audio_parser: moved code to separate functionsMax Kellermann2009-10-211-29/+78
|
* output: convert config_audio_format to an audio_format structMax Kellermann2009-10-213-14/+16
| | | | This allows more sophisticated audio format selection.
* audio_parser: renamed parameter "error" to "error_r"Max Kellermann2009-10-212-10/+12
| | | | It's a double pointer.
* audio: removed config_param.value NULL checkMax Kellermann2009-10-211-1/+1
| | | | The value is always non-NULL.
* output/jack: make ringbuffer_size a size_tMax Kellermann2009-10-211-1/+1
|
* output/jack: connect to server on MPD startupMax Kellermann2009-10-211-69/+119
| | | | | .. and keep up the JACK connection while MPD runs. Allocate the ring buffers on the first open, and free them at MPD exit.
* output/jack: removed the empty "cancel" methodMax Kellermann2009-10-211-6/+0
| | | | | JACK doesn't need cancel() because it won't do much anyway. Buffers are small.
* output/jack: renamed parameter "error" to "error_r"Max Kellermann2009-10-211-12/+12
| | | | It's a double pointer.
* output/jack: implement the "pause" methodMax Kellermann2009-10-211-0/+41
| | | | Don't disconnect from JACK during pause.
* output/jack: renamed source to jack_output_plugin.cMax Kellermann2009-10-212-4/+4
|
* pulse: code rewrite using the asynchronous libpulse APIMax Kellermann2009-10-213-282/+765
| | | | | | | | This is a complete rewrite of the PulseAudio output plugin. It uses the asynchronous API, which gives us more control over everything. Additionally, it connects to the PulseAudio server on startup, and keeps this connection up while MPD runs. During pause, instead of closing the stream, it enables "cork".
* mixer_plugin: pass audio_output pointer to mixer_plugin.init()Max Kellermann2009-10-218-12/+20
| | | | | This allows the mixer object to access its associated audio output object.
* volume: added PIPE_EVENT_MIXERMax Kellermann2009-10-212-0/+19
| | | | | Flush the hardware volume cache, and send the MIXER idle event. This allows mixer plugins to detect volume changes.
* mixer_plugin: use GError for error handlingMax Kellermann2009-10-2010-79/+189
|
* output_init: renamed parameter "error" to "error_r"Max Kellermann2009-10-202-8/+8
| | | | It's a double pointer.