aboutsummaryrefslogtreecommitdiffstats
Commit message (Collapse)AuthorAgeFilesLines
* 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
| |
* | tcp_socket, udp_server: use g_io_channel_new_socket()Max Kellermann2011-09-202-10/+4
| |
* | Merge branch 'v0.16.x'Max Kellermann2011-09-2013-30/+119
|\|
| * fd_util: add function close_socket()Max Kellermann2011-09-207-8/+26
| | | | | | | | Wrap close(), use closesocket() on WIN32/WinSock.
| * fd_util: check HAVE_INOTIFY_INIT in headerMax Kellermann2011-09-201-0/+4
| | | | | | | | Don't provide the prototype if inotify_init() was not detected.
| * fd_util: include check.h, verify config.h was includedMax Kellermann2011-09-201-0/+2
| |
| * glib_socket.h: wrap g_io_channel_*_new() calls portablyMax Kellermann2011-09-206-16/+49
| | | | | | | | | | The server_socket library (used by the httpd output plugin) didn't check for WIN32, that's fixed now.
| * configure.ac: add option --enable-solaris-outputMax Kellermann2011-09-193-4/+34
| | | | | | | | | | Allow enabling the plugin explicitly without running Solaris, to test the build.
| * configure.ac: fix solaris result displayMax Kellermann2011-09-192-2/+4
| | | | | | | | Wrong variable name.
* | Set socket TCP keepalive option on incoming connectionsDan McGee2011-09-193-2/+24
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | If a connected host disappears without our knowledge, as can happen over wireless or a hibernating machine, we continue to hold the port open waiting for messages. Because we never try to send anything down this now-broken pipe, the connection will sit idle taking up a slot in our allowed incoming connections list. If enough of these happen, an unintended Denial of Service takes place, where all connection slots are filled with now-broken, never ending connections. Setting the TCP keepalive option at least allows these to time out after the default two hours, which is sufficient in the non-malicious case. Signed-off-by: Dan McGee <dan@archlinux.org>
* | output_plugin: the plugin allocates the audio_output objectMax Kellermann2011-09-1932-552/+830
| | | | | | | | | | | | Pass audio_output objects around instead of void pointers. This will give some more control to the plugin, and prepares for non-blocking audio outputs.
* | Makefile.am: rename SPARSE_SOURCES to SPARSE_SRCMax Kellermann2011-09-191-2/+2
| | | | | | | | Work around automake warning.
* | output/roar: check return valuesMax Kellermann2011-09-181-2/+10
| | | | | | | | Fixes gcc warnings.
* | output/roar: unknown volume is -1, not 0Max Kellermann2011-09-181-1/+1
| |
* | output/roar: move code to roar_cancel_locked() and othersMax Kellermann2011-09-181-39/+55
| | | | | | | | Wrap the locking code.
* | output/roar: use GLib memory allocation functionsMax Kellermann2011-09-171-11/+3
| | | | | | | | GLib has a built-in OOM handler.
* | output/roar: use config_get_block_string() for temporaryMax Kellermann2011-09-171-8/+5
| |
* | output/roar: reorder methodsMax Kellermann2011-09-171-14/+14
| |
* | output: rename plugin variablesMax Kellermann2011-09-178-11/+11
| | | | | | | | Consistent naming.
* | Merge branch 'v0.16.x'Max Kellermann2011-09-172-11/+12
|\|
| * decoder/audiofile: include stdio header for SEEK_* definesTim Harder2011-09-171-0/+1
| | | | | | | | The stdio header is no longer pulled in by af_vfs.h in audiofile-0.3.0.
| * output/pulse: improve lockingMax Kellermann2011-09-171-11/+11
| | | | | | | | | | Always lock the main loop when operating on PULSE objects. Document this.
* | output: per-plugin headerMax Kellermann2011-09-1739-35/+440
| | | | | | | | | | Move the "extern" declarations from output_list.c, for more type safety.
* | output/pulse: don't expose internal struct in public headerMax Kellermann2011-09-174-36/+66
| | | | | | | | | | Provide _lock() and _unlock() to wrap all accesses from the mixer plugin.
* | output/raop: don't expose internal structs in public headerMax Kellermann2011-09-172-96/+95
| |
* | output/roar: export volume methodsMax Kellermann2011-09-174-46/+78
| | | | | | | | Use these instead of exposing the internal roar_t struct.
* | output: rename plugin source filesMax Kellermann2011-09-1710-9/+9
| |
* | output/pulse: move code to _setup_stream()Max Kellermann2011-09-171-15/+36
| |
* | input/soup: wait some more before resuming the streamMax Kellermann2011-09-161-1/+6
| |
* | input/soup: improve error messagesMax Kellermann2011-09-161-12/+43
| | | | | | | | | | Copy the reason_phrase from the SoupMessage, and check for transport errors in the session callback.
* | input_stream: non-blocking I/OMax Kellermann2011-09-1657-377/+653
| | | | | | | | | | | | | | | | | | Add GMutex, GCond attributes which will be used by callers to conditionally wait on the stream. Remove the (now-useless) plugin method buffer(), wait on GCond instead. Lock the input_stream before each method call. Do the same with the playlist plugins.
* | input_plugin: add method check()Max Kellermann2011-09-167-0/+78
| | | | | | | | | | To check for errors without reading. The decoder thread wants to do that, before it passes the input stream to the plugin.
* | input/{soup,curl}: free unused postponed_errorMax Kellermann2011-09-162-0/+8
| | | | | | | | Fix memory leak.
* | input/soup: move libsoup calls to the I/O threadMax Kellermann2011-09-161-4/+25
| | | | | | | | | | libsoup's asynchronous API is not thread safe. By moving the calls into the I/O thread, several crash bugs will be fixed.
* | input/soup: wait for _cancel_message() to completeMax Kellermann2011-09-161-5/+21
| | | | | | | | | | Add the "complete" attribute, and set it in _session_callback(). _close() waits for it to become true.