Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
* | | mixer/alsa: use DeferredMonitor to update file descriptors | Max Kellermann | 2014-01-04 | 1 | -14/+7 | |
| | | | | | | | | | | EventLoop::AddCall() and EventLoop::AddIdle() are unsafe, because we can't cancel those calls. | |||||
* | | event/BlockingCall: always use DeferredMonitor internally | Max Kellermann | 2014-01-04 | 1 | -24/+0 | |
| | | | | | | | | | | There is no advantage of using EventLoop::AddCall(), now that DeferredMonitor is thread-safe. | |||||
* | | event/DeferredMonitor: make fully thread-safe | Max Kellermann | 2014-01-04 | 4 | -54/+77 | |
| | | | | | | | | | | | | | | | | | | | | | | | | | | Instead of creating a new eventfd for each DeferredMonitor instance, reuse EventLoop's eventfd, and add a std::list to EventLoop that manages the list of pending DeferredMonitors. This std::list is protected by the same mutex as the "calls" list. The bottom line is: reduced overhead because the per-instance eventfd was eliminated, slightly added overhead due to Mutex usage (but negligible), and we're thread-safe now. This subsystem is now good enough to replace EventLoop::AddCall(). | |||||
* | | Added application key for soundcloud plugin | James McGlashan (DarkFox) | 2014-01-04 | 1 | -1/+2 | |
| | | ||||||
* | | Added soundcloud documentation | James McGlashan (DarkFox) | 2014-01-04 | 1 | -0/+41 | |
| | | ||||||
* | | Added user and search paramaters for SoundCloud plugin | James McGlashan (DarkFox) | 2014-01-04 | 1 | -0/+8 | |
| | | ||||||
* | | http -> https for SoundCloud plugin | James McGlashan (DarkFox) | 2014-01-02 | 2 | -6/+8 | |
| | | ||||||
* | | output/httpd: change "struct" to "class" | Max Kellermann | 2013-12-31 | 3 | -4/+7 | |
| | | ||||||
* | | output/httpd: move code to methods Delay(), Play(), Cancel() | Max Kellermann | 2013-12-31 | 2 | -22/+46 | |
| | | ||||||
* | | output/httpd: move Cast() into the class | Max Kellermann | 2013-12-31 | 2 | -25/+23 | |
| | | ||||||
* | | output/httpd: add methods Init(), Finish() | Max Kellermann | 2013-12-31 | 2 | -12/+29 | |
| | | ||||||
* | | output/httpd: use reference instead of pointer | Max Kellermann | 2013-12-31 | 3 | -14/+14 | |
| | | ||||||
* | | output/httpd: make the HttpdClient base class "private" | Max Kellermann | 2013-12-31 | 1 | -1/+1 | |
| | | ||||||
* | | event/*Monitor: document as not being thread-safe | Max Kellermann | 2013-12-31 | 4 | -0/+15 | |
| | | ||||||
* | | event/Loop: document that AddCall() is thread-safe | Max Kellermann | 2013-12-31 | 1 | -0/+5 | |
| | | ||||||
* | | command: "lsinfo" and "readcomments" allowed for remote files | Max Kellermann | 2013-12-29 | 6 | -0/+68 | |
| | | ||||||
* | | SongUpdate: read tags from songs in an archive | Max Kellermann | 2013-12-29 | 5 | -5/+131 | |
| | | | | | | | | | | Add the TagStream.cxx library, similar to TagFile.cxx, and use it to load tags from song files inside archives. | |||||
* | | InputStream: add static method OpenReady() | Max Kellermann | 2013-12-29 | 11 | -62/+47 | |
| | | | | | | | | Merge some duplicate code. | |||||
* | | TagFile: rewind the stream before trying the next plugin | Max Kellermann | 2013-12-29 | 1 | -1/+2 | |
| | | | | | | | | Got lost in commit c97685fe | |||||
* | | DecoderList: add "pure" attribute | Max Kellermann | 2013-12-29 | 1 | -0/+1 | |
| | | ||||||
* | | DecoderList: add function decoder_plugins_supports_suffix() | Max Kellermann | 2013-12-29 | 4 | -54/+20 | |
| | | | | | | | | Replaces decoder_plugin_from_suffix(). | |||||
* | | DecoderThread: use decoder_plugins_try() | Max Kellermann | 2013-12-29 | 1 | -32/+44 | |
| | | | | | | | | | | .. instead of decoder_plugin_from_suffix(). This reduces overhead by walking the array only once. | |||||
* | | UpdateContainer: pass suffix instead of DecoderPlugin | Max Kellermann | 2013-12-29 | 3 | -6/+18 | |
| | | | | | | | | | | Instead of using the first DecoderPlugin that supports the suffix, use the first one that actually implements the "container_scan" method. | |||||
* | | TagFile: pass reference instead of pointer | Max Kellermann | 2013-12-29 | 5 | -9/+6 | |
| | | ||||||
* | | TagFile: use decoder_plugins_try() | Max Kellermann | 2013-12-29 | 1 | -41/+54 | |
| | | | | | | | | | | | | .. instead of decoder_plugin_from_suffix(). This reduces overhead by walking the array only once. | |||||
* | | DecoderList: remove unused function decoder_plugin_from_mime_type() | Max Kellermann | 2013-12-29 | 2 | -25/+0 | |
| | | ||||||
* | | Merge branch 'v0.18.x' | Max Kellermann | 2013-12-29 | 3 | -9/+18 | |
|\| | ||||||
| * | configure.ac: improved check for libyajl 1.0 | Max Kellermann | 2013-12-29 | 2 | -1/+3 | |
| | | | | | | | | | | | | | | | | If we have libyajl 2.0.1 (without a pkg-config file), our configure.ac would assume this is the libyajl 1.0 API, because the function yajl_alloc() exists in both. This commit changes the library check to the function yajl_parse_complete() which was removed in the 2.0 API. This fixes build failure with libyajl 2.0.1. | |||||
| * | daemon: no initgroups() when already running as the configured user | Max Kellermann | 2013-12-29 | 2 | -1/+7 | |
| | | | | | | | | | | We can assume that initgroups() would be a no-op in that case, however initgroups() is not allowed for unprivileged users anyway. | |||||
| * | Daemon: fix typo in comment | Max Kellermann | 2013-12-29 | 1 | -1/+1 | |
| | | ||||||
| * | Daemon: simplify nested "if" | Max Kellermann | 2013-12-29 | 1 | -5/+4 | |
| | | ||||||
| * | Daemon: fix typo in cast | Max Kellermann | 2013-12-29 | 1 | -1/+1 | |
| | | ||||||
| * | configure.ac: prepare for 0.18.7 | Max Kellermann | 2013-12-29 | 2 | -1/+3 | |
| | | ||||||
* | | input/smbclient: new input plugin | Max Kellermann | 2013-12-29 | 8 | -0/+274 | |
| | | ||||||
* | | ls: add "pure" attribute | Max Kellermann | 2013-12-29 | 1 | -0/+3 | |
| | | ||||||
* | | pcm/Volume: remove unused function pcm_volume_dither() | Max Kellermann | 2013-12-28 | 1 | -16/+0 | |
| | | ||||||
* | | pcm/PcmMix: improved dithering | Max Kellermann | 2013-12-28 | 5 | -25/+48 | |
| | | | | | | | | Use the existing PcmDither library. | |||||
* | | pcm/Volume: improved dithering | Max Kellermann | 2013-12-28 | 6 | -22/+59 | |
| | | | | | | | | | | Instead of just adding a rectangular random value before shifting back to the normal scale, use the existing PcmDither library. | |||||
* | | pcm/PcmDither: inline Dither24To16() and Dither32To16() | Max Kellermann | 2013-12-28 | 3 | -4/+5 | |
| | | ||||||
* | | pcm/Volume: remove optimized i386 assembly | Max Kellermann | 2013-12-28 | 1 | -50/+0 | |
| | | | | | | | | | | This code is unable to dither. Until we implement that, let's remove the code for now. i386 isn't relevant anymore anyway. | |||||
* | | pcm/Traits: use 32 bit integer for S8 long_type | Max Kellermann | 2013-12-25 | 1 | -1/+1 | |
| | | | | | | | | 16 bit is not enough for volume calculations. | |||||
* | | pcm/Dither: add API documentation | Max Kellermann | 2013-12-24 | 1 | -0/+18 | |
| | | ||||||
* | | pcm/Dither: move shift from DitherConvert() to Dither() | Max Kellermann | 2013-12-24 | 1 | -2/+2 | |
| | | | | | | | | All callers need this shift, so let's move it to the basic method. | |||||
* | | pcm/Dither: rename DitherShift() to DitherConvert() | Max Kellermann | 2013-12-24 | 2 | -11/+11 | |
| | | ||||||
* | | test/*: use fprintf(stderr,...) and Log() instead of g_printerr() | Max Kellermann | 2013-12-24 | 12 | -110/+102 | |
| | | | | | | Avoid GLib. | |||||
* | | test/*: remove GLib logging setup | Max Kellermann | 2013-12-24 | 5 | -60/+0 | |
| | | | | | | | | Obsolete, our logging library doesn't ues GLib anymore. | |||||
* | | Merge tag 'release-0.18.6' | Max Kellermann | 2013-12-24 | 6 | -8/+21 | |
|\| | ||||||
| * | release v0.18.6 | Max Kellermann | 2013-12-24 | 2 | -2/+2 | |
| | | ||||||
| * | PlayerThread: log the last song that was played | Max Kellermann | 2013-12-24 | 1 | -1/+4 | |
| | | ||||||
| * | OutputControl: update both ReplayGainFilters | Max Kellermann | 2013-12-24 | 2 | -0/+3 | |
| | | | | | | | | | | The "mode" of the second ReplayGainFilter was never set, and thus replay gain was never applied to the new song during cross-fade. |