aboutsummaryrefslogtreecommitdiffstats
Commit message (Collapse)AuthorAgeFilesLines
* audio_format: move code to sample_format_size()Max Kellermann2011-10-081-6/+13
| | | | | Cast to enum sample_format. Without the cast, it's just a plain integer, and gcc cannot know that a "case" statement is missing.
* pcm_resample_lsr: move common code to lsr_process()Max Kellermann2011-10-081-32/+17
|
* output/roar: move code to _use_audio_format()Max Kellermann2011-10-081-27/+38
|
* db_print: print absolute URI of playlist entriesMax Kellermann2011-10-083-5/+21
| | | | | | | The protocol mandates that playlist URIs are absolute (i.e. full URI relative to the music directory, not relative to the parent directory). This adds the parameter "directory" to the "playlist" visitor method.
* Merge branch 'v0.16.x'Max Kellermann2011-10-084-13/+26
|\
| * output/openal: auto-fallback to mono if channel count is unsupportedMax Kellermann2011-10-082-9/+11
| | | | | | | | .. instead of failing playback completely.
| * output/alsa: remove "default" case from switchMax Kellermann2011-10-081-3/+6
| | | | | | | | Allow gcc to warn when a new format isn't supported.
| * configure.ac: disable systemd service by defaultMax Kellermann2011-10-071-1/+9
| | | | | | | | | | | | | | | | | | | | Defaulting to "with systemd" causes problems for users who install MPD as an unprivileged user, and it breaks "make distcheck". It looks like enabling it by default creates too many practical problems for unexperienced users. With --with-systemdsystemunitdir (without a parameter), configure.ac attempts to auto-detect systemd.
* | pcm_resample: add internal function _lsr_init()Max Kellermann2011-10-084-8/+26
| | | | | | | | Let the libsamplerate code initialize itself.
* | pcm_resample: one-time global initializationMax Kellermann2011-10-085-42/+84
| | | | | | | | | | Load the samplerate_converter on MPD startup. Fail if the converter name is invalid.
* | decoder/dsdiff: add option "lsbitfirst"Max Kellermann2011-10-072-1/+34
| | | | | | | | Defaults to "no", which fixes the noise problems.
* | decoder/dsdiff: add documentationMax Kellermann2011-10-072-0/+15
| |
* | playlist_song: allow references to songs outside the musicdirMax Kellermann2011-10-062-0/+8
| | | | | | | | | | | | When we have an absolute path that's not inside the music directory, allow loading it anyway, if we're in "secure" mode (i.e. the client is connected via UNIX socket).
* | Merge branch 'v0.16.x'Max Kellermann2011-10-0612-54/+173
|\| | | | | | | | | | | | | | | Conflicts: configure.ac src/player_control.c src/player_thread.c src/playlist_song.c
| * playlist_song: fix absolute path support in playlistsJesús Bravo Álvarez2011-10-062-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | Right now, a playlist with absolute pathnames can only add songs that are in the same the directory of the playlist or under it. If uri is an absolute pathname and base_uri is set, playlist_check_translate_song() will check that base_uri is a prefix of uri, excluding every other song in the music directory outside base_uri. I think in this case base_uri should be completely ignored (and made NULL) and uri should just be checked against music root directory.
| * player_thread: add flag "output_open", fixes assertion failureMax Kellermann2011-10-062-5/+18
| | | | | | | | | | | | | | Previously, the condition "defined(play_audio_format)" was used to see if an output device has been opened, but if the device had failed on startup, an assertion failure could occur. This patch adds a separate flag.
| * player_thread: move code to player_open_output()Max Kellermann2011-10-061-22/+37
| | | | | | | | | | Common function that manages "player" attributes after audio_output_all_open() has returned.
| * output_control: remove unused prototype _close_locked()Max Kellermann2011-10-061-3/+0
| |
| * player_control: auto-start playback when seeking is requestedMax Kellermann2011-10-062-3/+1
| | | | | | | | | | Now that the player thread can handle SEEK commands while not (yet) playing, we can remove the "pc.state" check from pc_seek().
| * player_thread: handle SEEK while not playingMax Kellermann2011-10-062-2/+13
| |
| * decoder_api: call _prepare_initial_seek() in decoder_tag()Max Kellermann2011-10-061-1/+1
| | | | | | | | | | This checks both conditions: pending and running. Fixes yet another assertion failure!
| * decoder_api: move code to _prepare_initial_seek()Max Kellermann2011-10-061-7/+31
| | | | | | | | .. and add a few code comments.
| * decoder_control: add attributes start_ms, end_msMax Kellermann2011-10-055-6/+31
| | | | | | | | | | Don't read song.start_ms and song.end_ms, let the player thread manage this logic instead.
| * decoder_api: don't copy tag to pipe during initial seekMax Kellermann2011-10-051-3/+8
| | | | | | | | Fixes one more assertion failure.
| * decoder_api: clear initial_seek_running on errorMax Kellermann2011-10-041-1/+3
| | | | | | | | Fixes possible assertion failure.
| * Install systemd service file if systemd is availableMiklos Vajna2011-09-304-0/+27
| |
* | decoder/dsdiff: new decoder pluginMax Kellermann2011-10-045-0/+516
| | | | | | | | | | Doesn't seem to work yet, getting just noise from a test file. Seeking isn't implemented yet.
* | Makefile.am: build the "dsd2pcm" programMax Kellermann2011-10-041-0/+9
| |
* | dsd2pcm/noiseshape: fix typo in C++ checkMax Kellermann2011-10-041-2/+2
| |
* | dsd2pcm: fix prototypesMax Kellermann2011-10-042-3/+3
| | | | | | | | Fixes gcc warnings.
* | import dsd2pcm_src.zipSebastian Gesemann2011-10-048-0/+637
| | | | | | | | | | | | | | [this is the code from dsd2pcm_src.zip, published on a forum by Sebastian Gesemann. Upon request, he has given permission to redistribute and modify his code, without referring to a specific license. - mk]
* | audio_format: add constant MAX_CHANNELSMax Kellermann2011-10-041-1/+3
| | | | | | | | To be used in fixed-size arrays.
* | configure.ac: add automake conditional HAVE_CXXMax Kellermann2011-10-031-0/+1
| |
* | test/run_decoder: initialize GThreadMax Kellermann2011-10-031-0/+1
| | | | | | | | Needed for the I/O thread.
* | Add support for streaming to a DLNA clientSteven Blackburn2011-09-302-5/+36
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The Naim Uniti does not appear to support icecast-style streaming of FLAC music but does support the codec from a DLNA server. This change looks for "transferMode.dlna.org: Streaming" in the HTTP request header and responds with something the Uniti (and hopefully other DLNA clients) accepts. The only difference in the DLNA streaming mode is the reponse header and that icecast metadata is disabled. If a client request indicates both modes are supported, the DLNA mode is preferred (as the Uniti says it supports both but then rejects a FLAC ICY stream). Note: This change may be specific to Naim equipment (the only device it was tested on). E.g. the hardcoding of Content-Length which works but is not a logically correct value. The change should be backwards-compatible, so only those clients requesting a DLNA stream will see any difference.
* | Merge branch 'v0.16.x'Max Kellermann2011-09-227-18/+81
|\| | | | | | | | | Conflicts: src/player_thread.c
| * decoder_api: emulate SEEK command for initial seek to CUE trackMax Kellermann2011-09-225-16/+74
| | | | | | | | | | | | | | | | | | | | | | | | | | When playing a CUE track, the player thread waited for the decoder to become ready, and then sent a SEEK command to the beginning of the CUE track. If that is near the start of the song file, and the track is short enough, the decoder could have finished decoding already at that point, and seeking fails. This commit makes this initial seek more robust: instead of letting the player thread deal with the difficult timings, let the decoder API emulate a SEEK command, and return it to the decoder plugin, as soon as the plugin finishes its initialization.
| * decoder_internal.h: more API documentationMax Kellermann2011-09-221-0/+5
| |
| * utils: uri.h: fix a typo: "schema"Jonathan Neuschäfer2011-09-211-1/+1
| |
| * configure.ac: fix --enable-id3 help stringMax Kellermann2011-09-201-1/+1
| |
* | protocol: drop G_GNUC_PURE from client_message_dupJonathan Neuschäfer2011-09-211-1/+1
| |
* | utils: mark sockaddr_to_string() as G_GNUC_MALLOCJonathan Neuschäfer2011-09-211-0/+1
| |
* | Simplify setsockopt() casting workaroundDan McGee2011-09-212-20/+6
| | | | | | | | | | | | | | | | | | On Win32, the third setsockopt parameter has type (char *) while on POSIX systems it is (void *). However, given that it is a no-op cast to go from a char pointer to a void pointer, we can cast to a char pointer (with a possible const modifier) on all platforms and satisfy the compiler. Signed-off-by: Dan McGee <dan@archlinux.org>
* | tcp_connect: generic library for establishing TCP connectionsMax Kellermann2011-09-204-0/+524
| |
* | io_thread: add function _timeout_add()Max Kellermann2011-09-202-0/+13
| | | | | | | | | | Same as _timeout_add_seconds(), but this one has millisecond resolution.
* | io_thread: _timeout_add_seconds() returns GSource*Max Kellermann2011-09-202-5/+5
| | | | | | | | The numeric ID isn't so useful.
* | server_socket: use resolve_host_port() instead of getaddrinfo()Max Kellermann2011-09-203-17/+9
| | | | | | | | Allow port specification in "bind_to_address" settings.
* | resolver: add function resolve_host_port()Max Kellermann2011-09-204-2/+157
| |
* | socket_util: move sockaddr_to_string() to resolver.cMax Kellermann2011-09-208-65/+128
| |
* | rtsp_client, output/raop: use close_socket() instead of close()Max Kellermann2011-09-202-5/+7
| |