| Commit message (Collapse) | Author | Age | Files | Lines |
|
|
|
|
|
| |
Export the decoder_plugins array. The function
decoder_plugin_print_all_decoders() it is UI specific and should not
live in this backend library.
|
|
|
|
|
| |
Before calling the plugin's decode method, we should ensure that we
didn't receive a STOP command during initialization.
|
|
|
|
|
|
| |
This function opens the stream and waits for it to become ready;
meanwhile it checks for STOP commands. It is code moved from
decoder_run_stream().
|
|
|
|
| |
Simplify the expressions.
|
|
|
|
| |
Make valgrind happy.
|
|
|
|
| |
Remove the static integer hack, that's not thread safe and sucks.
|
| |
|
|
|
|
| |
A NULL terminated list is easier to iterate.
|
|
|
|
|
|
| |
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.
|
|
|
|
| |
Tame the large decoder_run_song() function.
|
|
|
|
| |
Let gcc optimize a little bit more.
|
|
|
|
|
| |
No CamelCase. Use bool instead of int. Make both arguments
mandatory.
|
|
|
|
|
|
| |
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.
|
|
|
|
|
| |
Support up to 16 configured destination ports, that should really be
enough for everybody.
|
|
|
|
| |
Be more clear which kind of port should be configured here.
|
|
|
|
| |
Use the same name as in the libjack API documentation.
|
|
|
|
|
|
|
|
| |
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.
|
| |
|
|
|
|
| |
Added an interface for loading playlists from a local file.
|
|
|
|
|
| |
This new plugin parses extm3u files. Files without the "#EXTM3U"
header are still parsed by the plain old "m3u" plugin.
|
|
|
|
| |
The caller is responsible for verifying the song URI.
|
|
|
|
|
|
| |
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.
|
|
|
|
|
|
| |
Implement the methods enable() and disable(). Bind the HTTP port in
the enable() method, but reject all incoming connections until the
output is opened.
|
|
|
|
|
| |
When MPD plays a mono song (audio_format.channel==1), connect only one
source port to both destination ports.
|
|
|
|
|
|
| |
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.
|
|
|
|
|
|
|
|
| |
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".
|
| |
|
|
|
|
|
|
| |
Instead of using MPD's audio output name (setting "name"), use a
separate configuration option. Change the default to "Music Player
Daemon".
|
|
|
|
|
|
| |
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.
|
|
|
|
|
|
| |
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.
|
|
|
|
| |
Convert a string into a tag_type enum.
|
|
|
|
|
| |
Clear the colon. This simplifies all attribute parsers, because they
can now use strcmp() instead of strncmp().
|
|
|
|
| |
If left uninitialized, then the decoder thread quits spuriously.
|
|\ |
|
| |
| |
| |
| | |
Signed-off-by: Romain Bignon <romain@peerfuse.org>
|
| |
| |
| |
| |
| | |
If no song was queued, then player_control.next_song might contain the
value for the next QUEUE command. We must not reset that.
|
| |
| |
| |
| |
| |
| |
| | |
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.
|
| |
| |
| |
| |
| | |
The assertion shouldn't access player_control.next_song without
locking it.
|
| |
| |
| |
| | |
Simplify several expressions.
|
| |
| |
| |
| | |
Don't access attributes without the lock.
|
| |
| |
| |
| | |
Don't access decoder_control attributes directly.
|
| |
| |
| |
| | |
Lock the player_control object when modifying its attributes.
|
| | |
|
| |
| |
| |
| |
| | |
Asynchronous decoder startup is gone, and we don't need to check
command==DECODE_COMMAND_START anymore.
|
| |
| |
| |
| | |
These two variables are redundant, we need only one of them.
|
| |
| |
| |
| | |
It's not used if pc.error==PLAYER_ERROR_AUDIO.
|
| |
| |
| |
| |
| |
| | |
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.
|
| |
| |
| |
| |
| | |
The START command returns without blocking; we don't need the
asynchronous decoder start anymore.
|
| |
| |
| |
| |
| | |
Return the result to the caller more quickly. This unifies error
handling: no error can be reported before the command is finished.
|
|/
|
|
| |
They are just informational.
|