Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | encoder: renaming none_encoder to null_encoder | Viliam Mateicka | 2009-10-26 | 2 | -27/+27 |
| | |||||
* | mpd.conf: new bool config value for enabling/disabling inotify update | Viliam Mateicka | 2009-10-26 | 3 | -2/+8 |
| | |||||
* | encoder: new encoder plugin which just pass data through | Viliam Mateicka | 2009-10-24 | 2 | -0/+126 |
| | |||||
* | add --disable-inotify for configure to disable inotify when autodetected | Viliam Mateicka | 2009-10-24 | 1 | -0/+7 |
| | |||||
* | output/jack: implement methods enable()/disable() | Max Kellermann | 2009-10-23 | 1 | -16/+24 |
| | | | | Don't connect to JACK before MPD has daemonized. | ||||
* | output/pulse: implement methods enable()/disable() | Max Kellermann | 2009-10-23 | 1 | -9/+35 |
| | | | | Don't connect to PulseAudio before MPD has daemonized. | ||||
* | output_plugin: added methods enable() and disable() | Max Kellermann | 2009-10-23 | 15 | -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 changes | Max Kellermann | 2009-10-23 | 4 | -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() fails | Max Kellermann | 2009-10-23 | 1 | -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 unavailable | Max Kellermann | 2009-10-23 | 2 | -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 NULL | Max Kellermann | 2009-10-23 | 2 | -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 ready | Max Kellermann | 2009-10-22 | 1 | -3/+3 |
| | | | | Moved the check from pulse_mixer_open() to pulse_mixer_update(). | ||||
* | output/fifo: renamed source to fifo_output_plugin.c | Max Kellermann | 2009-10-22 | 1 | -3/+3 |
| | |||||
* | audio: removed function finishAudioConfig() | Max Kellermann | 2009-10-22 | 3 | -8/+0 |
| | | | | There's no point in clearing the audio format before exiting. | ||||
* | main: put #ifdef inside winsock_init() | Max Kellermann | 2009-10-22 | 1 | -5/+2 |
| | | | | | This way, the function call in the main() function does not need another pair of #ifdef/#endif. | ||||
* | permission: improve const-correctness | SF Markus Elfring | 2009-10-22 | 2 | -2/+2 |
| | |||||
* | playlist: new ASX playlist plugin | Max Kellermann | 2009-10-21 | 3 | -0/+340 |
| | | | | Based on the XSPF playlist plugin. | ||||
* | playlist/xspf: ignore text in root, playlist, tracklist | Max Kellermann | 2009-10-21 | 1 | -0/+2 |
| | | | | Added a missing "break". | ||||
* | audio_format: wildcards allowed in audio_format configuration | Max Kellermann | 2009-10-21 | 7 | -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 functions | Max Kellermann | 2009-10-21 | 1 | -29/+78 |
| | |||||
* | output: convert config_audio_format to an audio_format struct | Max Kellermann | 2009-10-21 | 3 | -14/+16 |
| | | | | This allows more sophisticated audio format selection. | ||||
* | audio_parser: renamed parameter "error" to "error_r" | Max Kellermann | 2009-10-21 | 2 | -10/+12 |
| | | | | It's a double pointer. | ||||
* | audio: removed config_param.value NULL check | Max Kellermann | 2009-10-21 | 1 | -1/+1 |
| | | | | The value is always non-NULL. | ||||
* | output/jack: make ringbuffer_size a size_t | Max Kellermann | 2009-10-21 | 1 | -1/+1 |
| | |||||
* | output/jack: connect to server on MPD startup | Max Kellermann | 2009-10-21 | 1 | -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" method | Max Kellermann | 2009-10-21 | 1 | -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 Kellermann | 2009-10-21 | 1 | -12/+12 |
| | | | | It's a double pointer. | ||||
* | output/jack: implement the "pause" method | Max Kellermann | 2009-10-21 | 1 | -0/+41 |
| | | | | Don't disconnect from JACK during pause. | ||||
* | output/jack: renamed source to jack_output_plugin.c | Max Kellermann | 2009-10-21 | 2 | -4/+4 |
| | |||||
* | pulse: code rewrite using the asynchronous libpulse API | Max Kellermann | 2009-10-21 | 3 | -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 Kellermann | 2009-10-21 | 8 | -12/+20 |
| | | | | | This allows the mixer object to access its associated audio output object. | ||||
* | volume: added PIPE_EVENT_MIXER | Max Kellermann | 2009-10-21 | 2 | -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 handling | Max Kellermann | 2009-10-20 | 10 | -79/+189 |
| | |||||
* | output_init: renamed parameter "error" to "error_r" | Max Kellermann | 2009-10-20 | 2 | -8/+8 |
| | | | | It's a double pointer. | ||||
* | mixer/{oss,alsa}: renamed the mixer source files | Max Kellermann | 2009-10-20 | 5 | -12/+14 |
| | |||||
* | output/pulse: renamed context to "Music Player Daemon" | Max Kellermann | 2009-10-20 | 1 | -1/+1 |
| | | | | This looks nicer in the PulseAudio manager than just "mpd". | ||||
* | pulse: renamed source files | Max Kellermann | 2009-10-20 | 4 | -8/+10 |
| | |||||
* | pulse: announce "media.role=music" | Max Kellermann | 2009-10-20 | 1 | -0/+2 |
| | | | | This allows PulseAudio to do some advanced tweaks. | ||||
* | main: call g_set_application_name() | Max Kellermann | 2009-10-20 | 1 | -0/+2 |
| | | | | | | I'm not sure about the advantages of calling g_set_application_name(), because I don't use a task manager (except for ps and kill), but it sure doesn't hurt. | ||||
* | mapper, update, ...: use g_build_filename(), G_DIR_SEPARATOR, ... | Max Kellermann | 2009-10-20 | 7 | -11/+10 |
| | | | | | Try to be as portable as possible, use GLib path name functions and macros. | ||||
* | Merged release 0.15.5 from branch 'v0.15.x' | Max Kellermann | 2009-10-18 | 3 | -9/+11 |
|\ | | | | | | | | | | | | | | | Conflicts: NEWS configure.ac src/decoder/flac_plugin.c src/update.c | ||||
| * | decoder/flac: fixed two memory leaks in the CUE tag loader | Max Kellermann | 2009-10-16 | 1 | -2/+3 |
| | | | | | | | | | | | | Don't initialize "vc" and "cs" with FLAC__metadata_object_new(); that value is overwritten by FLAC__metadata_get_tags() and FLAC__metadata_get_cuesheet(). | ||||
| * | update: fixed memory leak during container scan | Max Kellermann | 2009-10-16 | 1 | -3/+6 |
| | | | | | | | | The return value of map_directory_child_fs() must be freed. | ||||
| * | update: song_file_new() cannot fail | Max Kellermann | 2009-10-16 | 1 | -3/+0 |
| | | | | | | | | | | Removed the NULL check. If that NULL check was correct, that would have been a memory leak (vtrack). | ||||
| * | output_thread: check again if output is open on CANCEL | Max Kellermann | 2009-10-16 | 1 | -1/+2 |
| | | | | | | | | | | | | | | | | When the player thread unpauses, it sends CANCEL to the output thread, after having checked that the output is still open. Problem is when the output thread closes the device before it can process the CANCEL command - race condition. This patch adds another "open" check inside the output thread. | ||||
* | | decoder/vorbis: avoid unused symbol warnings from vorbisfile.h | Serge Ziryukin | 2009-10-18 | 1 | -0/+1 |
| | | | | | | | | | | | | | | | | svn r13289 of libvorbis introduced static callbacks (like OV_CALLBACKS_DEFAULT) defined in "vorbisfile.h" header. First released version with this change is libvorbis-1.2.2. In libversion-1.2.3 OV_EXCLUDE_STATIC_CALLBACKS define was added to avoid warnings about unused static callbacks. Information on the OV_EXCLUDE_STATIC_CALLBACKS can be found in http://svn.xiph.org/trunk/vorbis/CHANGES. | ||||
* | | command: omitting the range end is possible | Max Kellermann | 2009-10-18 | 1 | -1/+4 |
| | | | | | | | | | | When the range end is missing, then the maximum possible value is assumed. | ||||
* | | command: use GLib limit macros in check_range() | Max Kellermann | 2009-10-18 | 1 | -10/+10 |
| | | | | | | | | These are portable and don't require limits.h. | ||||
* | | command: allow changing replay gain mode on-the-fly | Max Kellermann | 2009-10-17 | 3 | -1/+63 |
| | | | | | | | | | | The new command "replay_gain_mode" allows the user to switch the replay gain mode on-the-fly. No more mpd.conf editing. | ||||
* | | replay_gain: moved mode parser to replay_gain_set_mode_string() | Max Kellermann | 2009-10-17 | 1 | -6/+19 |
| | |