aboutsummaryrefslogtreecommitdiffstats
path: root/src (follow)
Commit message (Collapse)AuthorAgeFilesLines
...
* | event/DeferredMonitor: make fully thread-safeMax Kellermann2014-01-044-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 pluginJames McGlashan (DarkFox)2014-01-041-1/+2
| |
* | Added user and search paramaters for SoundCloud pluginJames McGlashan (DarkFox)2014-01-041-0/+8
| |
* | http -> https for SoundCloud pluginJames McGlashan (DarkFox)2014-01-021-6/+6
| |
* | output/httpd: change "struct" to "class"Max Kellermann2013-12-313-4/+7
| |
* | output/httpd: move code to methods Delay(), Play(), Cancel()Max Kellermann2013-12-312-22/+46
| |
* | output/httpd: move Cast() into the classMax Kellermann2013-12-312-25/+23
| |
* | output/httpd: add methods Init(), Finish()Max Kellermann2013-12-312-12/+29
| |
* | output/httpd: use reference instead of pointerMax Kellermann2013-12-313-14/+14
| |
* | output/httpd: make the HttpdClient base class "private"Max Kellermann2013-12-311-1/+1
| |
* | event/*Monitor: document as not being thread-safeMax Kellermann2013-12-314-0/+15
| |
* | event/Loop: document that AddCall() is thread-safeMax Kellermann2013-12-311-0/+5
| |
* | command: "lsinfo" and "readcomments" allowed for remote filesMax Kellermann2013-12-294-0/+59
| |
* | SongUpdate: read tags from songs in an archiveMax Kellermann2013-12-293-5/+128
| | | | | | | | | | 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 Kellermann2013-12-297-15/+41
| | | | | | | | Merge some duplicate code.
* | TagFile: rewind the stream before trying the next pluginMax Kellermann2013-12-291-1/+2
| | | | | | | | Got lost in commit c97685fe
* | DecoderList: add "pure" attributeMax Kellermann2013-12-291-0/+1
| |
* | DecoderList: add function decoder_plugins_supports_suffix()Max Kellermann2013-12-294-54/+20
| | | | | | | | Replaces decoder_plugin_from_suffix().
* | DecoderThread: use decoder_plugins_try()Max Kellermann2013-12-291-32/+44
| | | | | | | | | | .. instead of decoder_plugin_from_suffix(). This reduces overhead by walking the array only once.
* | UpdateContainer: pass suffix instead of DecoderPluginMax Kellermann2013-12-293-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 pointerMax Kellermann2013-12-295-9/+6
| |
* | TagFile: use decoder_plugins_try()Max Kellermann2013-12-291-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 Kellermann2013-12-292-25/+0
| |
* | Merge branch 'v0.18.x'Max Kellermann2013-12-291-8/+11
|\|
| * daemon: no initgroups() when already running as the configured userMax Kellermann2013-12-291-1/+5
| | | | | | | | | | 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 commentMax Kellermann2013-12-291-1/+1
| |
| * Daemon: simplify nested "if"Max Kellermann2013-12-291-5/+4
| |
| * Daemon: fix typo in castMax Kellermann2013-12-291-1/+1
| |
* | input/smbclient: new input pluginMax Kellermann2013-12-294-0/+238
| |
* | ls: add "pure" attributeMax Kellermann2013-12-291-0/+3
| |
* | pcm/Volume: remove unused function pcm_volume_dither()Max Kellermann2013-12-281-16/+0
| |
* | pcm/PcmMix: improved ditheringMax Kellermann2013-12-284-19/+38
| | | | | | | | Use the existing PcmDither library.
* | pcm/Volume: improved ditheringMax Kellermann2013-12-284-20/+54
| | | | | | | | | | 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 Kellermann2013-12-282-3/+4
| |
* | pcm/Volume: remove optimized i386 assemblyMax Kellermann2013-12-281-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_typeMax Kellermann2013-12-251-1/+1
| | | | | | | | 16 bit is not enough for volume calculations.
* | pcm/Dither: add API documentationMax Kellermann2013-12-241-0/+18
| |
* | pcm/Dither: move shift from DitherConvert() to Dither()Max Kellermann2013-12-241-2/+2
| | | | | | | | All callers need this shift, so let's move it to the basic method.
* | pcm/Dither: rename DitherShift() to DitherConvert()Max Kellermann2013-12-242-11/+11
| |
* | Merge tag 'release-0.18.6'Max Kellermann2013-12-245-7/+15
|\|
| * PlayerThread: log the last song that was playedMax Kellermann2013-12-241-1/+4
| |
| * OutputControl: update both ReplayGainFiltersMax Kellermann2013-12-241-0/+2
| | | | | | | | | | The "mode" of the second ReplayGainFilter was never set, and thus replay gain was never applied to the new song during cross-fade.
| * fix FfmpegDecoderPlugin to use relative timestampsSteven O'Brien2013-12-201-4/+6
| |
| * util/Error: add missing <algorithm> includeMax Kellermann2013-12-191-0/+1
| | | | | | | | For std::move().
| * riff: recognize upper-case "ID3" chunk nameMichal Smucr2013-12-191-1/+2
| | | | | | | | Some tagging libraries (eg. TagLib) produce that variant.
| * input/cdio: fix typo in #include pathMax Kellermann2013-12-171-1/+1
| | | | | | | | Broken by commit 3b0fea5f
* | OutputThread: handle failing ReplayGainFilter::Open()Max Kellermann2013-12-241-4/+10
| | | | | | | | | | Since opening the PcmVolume object can now fail, this case must be handled.
* | pcm/Volume: convert to classMax Kellermann2013-12-234-132/+156
| | | | | | | | Prepare for adding state.
* | pcm/Volume: apply volume into destination bufferMax Kellermann2013-12-231-21/+37
| |
* | pcm/Volume: convert i386 code to template specializationMax Kellermann2013-12-231-42/+42
| |