aboutsummaryrefslogtreecommitdiffstats
path: root/src (unfollow)
Commit message (Collapse)AuthorFilesLines
2009-11-07decoder_list: back to NULL terminated listMax Kellermann1-7/+8
A NULL terminated list is easier to iterate.
2009-11-07decoder_thread: open input stream on demandMax Kellermann1-72/+59
Moved the global input stream opener to decoder_run_stream(). decoder_run_file() now opens the input stream each time a plugin provides a stream decoder method.
2009-11-07decoder_thread: moved plugin loops to separate functionsMax Kellermann1-82/+127
Tame the large decoder_run_song() function.
2009-11-07uri: added function attributesMax Kellermann1-0/+5
Let gcc optimize a little bit more.
2009-11-06utils: renamed stringFoundInStringArray()Max Kellermann6-30/+35
No CamelCase. Use bool instead of int. Make both arguments mandatory.
2009-11-06output/jack: dynamic source port listMax Kellermann1-37/+74
Same as the previous patch: create up to 16 configured source ports. The plugin tries to do its best at guessing the right combination for the given input file, the number of source and destination ports.
2009-11-06output/jack: dynamic destination port listMax Kellermann1-25/+71
Support up to 16 configured destination ports, that should really be enough for everybody.
2009-11-06output/jack: renamed option "ports" to "destination_ports"Max Kellermann1-1/+9
Be more clear which kind of port should be configured here.
2009-11-06output/jack: renamed "output ports" to "destination ports"Max Kellermann1-18/+20
Use the same name as in the libjack API documentation.
2009-11-06playlist_queue: use playlist plugins to load from playlist_directoryMax Kellermann1-0/+33
This patch allows the client to load a playlist file from the playlist directory with a plugin. This can be used with the "load" command, but the client has to pass the file name including the suffix. We will probably use the music directory in the future, to support playlist files inside the music directory.
2009-11-06playlist_queue: moved code to playlist_open_remote_into_queue()Max Kellermann1-5/+12
2009-11-06playlist_list: added function playlist_list_open_path()Max Kellermann2-0/+47
Added an interface for loading playlists from a local file.
2009-11-06playlist: added extm3u pluginMax Kellermann3-0/+187
This new plugin parses extm3u files. Files without the "#EXTM3U" header are still parsed by the plain old "m3u" plugin.
2009-11-06playlist/{m3u,pls}: removed URI checksMax Kellermann2-7/+1
The caller is responsible for verifying the song URI.
2009-11-06playlist_list: rewind the stream before opening the playlistMax Kellermann1-0/+9
If one plugin has failed to open the playlist, it may have consumed a part of the stream already. This may lead to a failure in all following plugins. Fix: rewind the stream before each open() call.
2009-11-05output/httpd: bind port when output is enabledMax Kellermann2-13/+49
Implement the methods enable() and disable(). Bind the HTTP port in the enable() method, but reject all incoming connections until the output is opened.
2009-11-05output/jack: support mono inputMax Kellermann1-13/+41
When MPD plays a mono song (audio_format.channel==1), connect only one source port to both destination ports.
2009-11-05output/jack: clear ring buffers before activatingMax Kellermann1-1/+6
After playback has stopped, the ring buffers may still contain samples. These will be played when playback is started the next time. We should clear the buffers each time.
2009-11-05output/jack: use jack_client_open() instead of jack_client_new()Max Kellermann1-4/+23
jack_client_new() is deprecated. This requires libjack 0.100 (released nearly 5 years ago). We havn't been testing older libjack versions anyway. As a side effect, there is the new option "autostart".
2009-11-05output/jack: added option "client_name"Max Kellermann1-3/+2
Instead of using MPD's audio output name (setting "name"), use a separate configuration option. Change the default to "Music Player Daemon".
2009-11-05update_walk: log unrecognized filesMax Kellermann1-2/+9
When a song's tags could not be loaded during database update, log this as a debug message. Same for a song being removed because its updated tag could not be read.
2009-11-04database: rescan after metadata_to_use changeMax Kellermann1-0/+32
Store a list of supported tag items in the database. When loading a database which does not have a matching list, we must rescan in order to get the missing information.
2009-11-04tag: added function tag_name_parse()Max Kellermann4-26/+61
Convert a string into a tag_type enum.
2009-11-04song_save: explicitly parse the colonMax Kellermann1-18/+27
Clear the colon. This simplifies all attribute parsers, because they can now use strcmp() instead of strncmp().
2009-11-04decoder_thread: initialize decoder_control.quitMax Kellermann1-0/+2
If left uninitialized, then the decoder thread quits spuriously.
2009-11-04sticker comments in code and example configuration fileRomain Bignon1-0/+5
Signed-off-by: Romain Bignon <romain@peerfuse.org>
2009-11-03player_thread: on return, reset next_song only if queuedMax Kellermann1-3/+7
If no song was queued, then player_control.next_song might contain the value for the next QUEUE command. We must not reset that.
2009-11-03player_thread: detect finished queued songMax Kellermann1-1/+2
When the decoder finishes the "queued" song very quickly (before the "current" song finishes playing), an assertion in do_play() fails because it thinks that it should start decoding the queued song, although that has in fact just finished.
2009-11-03player_control: moved pc.next_song assertion into lockMax Kellermann1-1/+2
The assertion shouldn't access player_control.next_song without locking it.
2009-11-03player_thread: moved code to decoding_next_song()Max Kellermann1-4/+15
Simplify several expressions.
2009-11-03player_thread: lock player in player_check_decoder_startup()Max Kellermann1-0/+8
Don't access attributes without the lock.
2009-11-03decoder_control: pass pipe and buffer to dc_start()Max Kellermann3-14/+25
Don't access decoder_control attributes directly.
2009-11-03player_thread: lock inside player_wait_for_decoder()Max Kellermann1-7/+17
Lock the player_control object when modifying its attributes.
2009-11-03player_thread: moved code to player_dc_start()Max Kellermann1-5/+20
2009-11-03decoder_control: don't check command in decoder_is_starting()Max Kellermann1-5/+3
Asynchronous decoder startup is gone, and we don't need to check command==DECODE_COMMAND_START anymore.
2009-11-03decoder_control: merge next_song and current_songMax Kellermann5-16/+16
These two variables are redundant, we need only one of them.
2009-11-03player_thread: don't set errored_song on audio errorMax Kellermann1-2/+0
It's not used if pc.error==PLAYER_ERROR_AUDIO.
2009-11-03decoder_thread: unlock the decoder while checking the streamMax Kellermann1-4/+4
This is only a slight change to the previous locking behaviour: keep the decoder unlocked during the loop, and lock it only while checking decoder_control.command.
2009-11-03player_thread: don't start the decoder asynchronouslyMax Kellermann3-17/+2
The START command returns without blocking; we don't need the asynchronous decoder start anymore.
2009-11-03decoder_thread: open input stream after command finishedMax Kellermann1-5/+10
Return the result to the caller more quickly. This unifies error handling: no error can be reported before the command is finished.
2009-11-03decoder_control: make the song objects constMax Kellermann3-4/+4
They are just informational.
2009-11-02alsa_plugin.c: workaround snd_pcm_drain bugJeffrey Middleton1-1/+2
Reintroduce a fix from commit 52a0653 (Warren Dukes): "don't call snd_pcm_drain unless we're already in the RUNNING state". This prevents ALSA with dmix from sometimes hanging when snd_pcm_drain is called, e.g. when moving from one song to the next (as in mantis issue 2634).
2009-11-02output_thread: moved code to ao_next_chunk()Max Kellermann1-6/+11
2009-11-02output_thread: return from ao_play() if chunk->next is NULLMax Kellermann1-5/+4
When the "next" chunk to be played is NULL, return from ao_play() immediately, without going over the "while" loop (no-op).
2009-11-02player_thread: check command before waiting during pauseMax Kellermann1-1/+3
While paused, the player thread re-locks its mutex and waits for a signal. This is racy: when the command is set while the thread is waiting for the lock, it may wait forever. This patch adds another command check before player_wait().
2009-11-02output: signal the output thread when CANCEL is finishedMax Kellermann2-0/+34
After CANCEL, the output thread waits for another signal before it continues playback, to synchronize with the caller. There were some situations where this signal wasn't sent properly. This patch adds an explicit g_cond_signal() at two code positions.
2009-11-02update: removed unused variable "update_notify"Max Kellermann2-11/+0
That variable has been superseded by "remove_notify" (defined in update_remove.c).
2009-11-02{decoder,player}_control: removed duplicate wakeupsMax Kellermann3-7/+5
Don't wake up the target thread in every iteration of the wait() loop. Waking it up once, right after the command has been set, must be enough.
2009-11-02player_control: lock player before setting seek parametersMax Kellermann1-2/+6
These parameters must be protected with a mutex, too. Wrap everything inside player_lock()/player_unlock(), and use player_command_locked() instead of player_command().
2009-11-02output_thread: check command before g_cond_wait()Max Kellermann1-1/+2
After CANCEL, call g_cond_wait() only if the new command is still NONE. Problem is that ao_command_finished() has to unlock the audio_output object, and in the meantime, the player thread might have submitted a new command.