Yue Wang
|
f881917d2f
|
Fix a bug that buffer_frame_size is not properly initialized
|
2016-09-18 21:09:57 -07:00 |
|
Yue Wang
|
99244f51b0
|
Remove unused imports
|
2016-09-18 19:40:55 -07:00 |
|
Yue Wang
|
606d029ed9
|
Kill mutex and locks in osx_render. Improve performance. Also fix an initialization problem
|
2016-09-18 19:40:04 -07:00 |
|
Yue Wang
|
e4b9d679fb
|
options for sample rate syncing and device hogging
|
2016-09-18 19:12:45 -07:00 |
|
Yue Wang
|
2bf2bd8932
|
Add myself to authors
|
2016-09-18 13:33:48 -07:00 |
|
Yue Wang
|
4a8a33ea85
|
Hogging is for user selected device only.
do not hog system device.
|
2016-09-18 13:15:46 -07:00 |
|
Yue Wang
|
ac4b83046a
|
Add sample rate synchronization and device hogging to core audio plugin
which ensures mpd do bit perfect playback on OS X
|
2016-09-18 12:52:08 -07:00 |
|
Max Kellermann
|
2a2ac35b98
|
decoder/ffmpeg: FfmpegOpenInput() throws exception on error
|
2016-09-16 18:49:22 +02:00 |
|
Max Kellermann
|
8c744efd56
|
input/InputStream: migrate from class Error to C++ exceptions
|
2016-09-16 17:43:36 +02:00 |
|
Max Kellermann
|
597e59f10d
|
input/thread: use C++ exceptions instead of class Error
|
2016-09-16 17:43:32 +02:00 |
|
Max Kellermann
|
3cd07d0b54
|
input/thread: use class ScopeLock and ScopeUnlock
|
2016-09-16 17:43:32 +02:00 |
|
Max Kellermann
|
13259225c2
|
input/async: eliminate attribute "postponed_error"
Switch the remaining users to "postponed_exception".
|
2016-09-16 17:43:32 +02:00 |
|
Max Kellermann
|
7acd91331c
|
input/curl: use C++ exceptions instead of class Error
|
2016-09-16 17:43:32 +02:00 |
|
Max Kellermann
|
0fdaca17a2
|
input/alsa: use C++ exceptions instead of class Error
|
2016-09-16 17:43:32 +02:00 |
|
Max Kellermann
|
539c0ed171
|
{input,storage}/nfs: use C++ exceptions instead of class Error
|
2016-09-16 17:43:32 +02:00 |
|
Max Kellermann
|
553365b942
|
Log: add std::exception_ptr overloads
|
2016-09-16 17:43:32 +02:00 |
|
Max Kellermann
|
100308db02
|
db/update: catch exceptions from Storage plugins
|
2016-09-16 17:43:32 +02:00 |
|
Max Kellermann
|
ab967462e6
|
tag/{ApeLoader,Id3Load}: catch InputStream exceptions
|
2016-09-16 17:37:22 +02:00 |
|
Max Kellermann
|
1bc553ea62
|
decoder/DecoderAPI: catch InputStream::Read() exceptions
|
2016-09-16 17:34:53 +02:00 |
|
Max Kellermann
|
687ea53616
|
input/nfs: use class ScopeUnlock
|
2016-09-16 16:51:36 +02:00 |
|
Max Kellermann
|
220d9528a3
|
archive/Plugin: migrate open() from class Error to C++ exceptions
|
2016-09-09 18:36:36 +02:00 |
|
Max Kellermann
|
fc7d3f64c0
|
input/Plugin: migrate open() from class Error to C++ exceptions
|
2016-09-09 18:15:01 +02:00 |
|
Max Kellermann
|
63ab7767a3
|
event/Call: rethrow exceptions in calling thread
|
2016-09-09 18:14:21 +02:00 |
|
Max Kellermann
|
20894d1c5e
|
playlist/SoundCloud: use AtScopeExit()
|
2016-09-09 18:04:11 +02:00 |
|
Max Kellermann
|
2f03d2234a
|
playlist/SoundCloud: use std::string
|
2016-09-09 18:01:36 +02:00 |
|
Max Kellermann
|
dadf3d846b
|
playlist/SoundCloud: implicit SoundCloudJsonData initialization
|
2016-09-09 18:01:01 +02:00 |
|
Max Kellermann
|
941a9284b9
|
playlist/SoundCloud: rename struct parse_data to SoundCloudJsonData
|
2016-09-09 18:00:26 +02:00 |
|
Max Kellermann
|
4ee3820bd6
|
playlist/SoundCloud: make parse_callbacks constexpr
|
2016-09-09 17:59:42 +02:00 |
|
Max Kellermann
|
c155df5d79
|
playlist/SoundCloud: use ScopeLock
|
2016-09-09 17:59:07 +02:00 |
|
Max Kellermann
|
33b70567c8
|
input/alsa: use AtScopeExit()
|
2016-09-09 17:12:52 +02:00 |
|
Max Kellermann
|
720bf51ba6
|
input/alsa: simplify OpenDevice(), merge redundant recovery code
|
2016-09-09 17:12:52 +02:00 |
|
Max Kellermann
|
26bdb72428
|
input/Init: set input_plugins_enabled
Got lost in commit 6ed77f2a27
|
2016-09-09 17:12:52 +02:00 |
|
Max Kellermann
|
90c8a1b1cf
|
input/archive: use AtScopeExit() for exception-safety
|
2016-09-09 16:32:11 +02:00 |
|
Max Kellermann
|
3143dbf3dc
|
input/Open: use ScopeLock
|
2016-09-09 16:11:51 +02:00 |
|
Max Kellermann
|
38d587aaeb
|
decoder/wavpack: wavpack_open_wvc() returns InputStreamPtr
Let std::unique_ptr manage both the InputStream and the WavpackInput.
|
2016-09-09 16:04:57 +02:00 |
|
Max Kellermann
|
fe9bafa741
|
decoder/wavpack: use AtScopeExit() for exception-safety
|
2016-09-09 15:55:58 +02:00 |
|
Max Kellermann
|
8092e18158
|
input/async: add attribute "postponed_exception"
Will replace "postponed_error".
|
2016-09-09 15:41:09 +02:00 |
|
Max Kellermann
|
6ed77f2a27
|
input/Plugin: migrate init() from class Error to C++ exceptions
|
2016-09-09 15:16:47 +02:00 |
|
Max Kellermann
|
a73688a2be
|
input/Plugin: remove InitResult::UNAVAILABLE, throw PluginUnavailable instead
|
2016-09-09 15:11:52 +02:00 |
|
Max Kellermann
|
e7d327226a
|
mixer: migrate to C++ exceptions
|
2016-09-09 14:44:15 +02:00 |
|
Max Kellermann
|
ae1eb9ccde
|
pcm/Convert: migrate from class Error to C++ exceptions
|
2016-09-09 14:44:13 +02:00 |
|
Max Kellermann
|
860064c812
|
output/pulse: use a RTTI lock guard
Make all the locks exception-safe.
|
2016-09-09 14:36:24 +02:00 |
|
Max Kellermann
|
845901ab01
|
decoder/Internal: convert error from Error to std::exception_ptr
|
2016-09-08 20:56:05 +02:00 |
|
Max Kellermann
|
25f7360264
|
decoder/Thread: throw InputStream::Open() errors
Code simplification.
|
2016-09-08 20:54:55 +02:00 |
|
Max Kellermann
|
78ec7d0fe1
|
decoder/Thread: throw StopDecoder on DecoderCommand::STOP
|
2016-09-08 20:54:55 +02:00 |
|
Max Kellermann
|
a1e9678b69
|
decoder/Thread: std::throw_with_nested() to wrap caught exception
|
2016-09-08 20:54:55 +02:00 |
|
Max Kellermann
|
be5d629c13
|
Log: recognize class Error as nested exception
|
2016-09-08 20:54:55 +02:00 |
|
Max Kellermann
|
957b399e90
|
decoder/Thread: call FlushChunk() using AtScopeExit()
Be exception-safe.
|
2016-09-08 20:41:44 +02:00 |
|
Max Kellermann
|
5e6c164b9f
|
decoder/Internal: use C++11 initializers
|
2016-09-08 20:34:39 +02:00 |
|
Max Kellermann
|
5d9a889190
|
decoder/Thread: throw C++ exceptions on error
|
2016-09-08 20:26:40 +02:00 |
|