Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | lib/icu/Collate: use LCMapStringEx() on Windows | Max Kellermann | 2015-06-27 | 1 | -0/+29 |
| | |||||
* | lib/icu/Converter: remove GLib implementation | Max Kellermann | 2015-06-26 | 2 | -52/+2 |
| | | | | | We don't need this anymore: Win32 doesn't use this library at all, and everything else has either iconv() or libicu. | ||||
* | lib/icu/Converter: add iconv() implementation | Max Kellermann | 2015-06-26 | 2 | -2/+52 |
| | |||||
* | lib/icu/Converter: add missing <> | Max Kellermann | 2015-06-26 | 1 | -1/+1 |
| | |||||
* | lib/icu/{Converter,Collate}: return AllocatedString | Max Kellermann | 2015-06-25 | 6 | -41/+37 |
| | |||||
* | lib/icu/Collate: fall back to strxfrm() | Max Kellermann | 2015-06-25 | 1 | -2/+16 |
| | |||||
* | lib/icu/Collate: fix indent | Max Kellermann | 2015-06-25 | 1 | -3/+3 |
| | |||||
* | lib/icu/Collate: fall back to strcoll() instead of strcasecmp() | Max Kellermann | 2015-06-23 | 1 | -1/+1 |
| | |||||
* | lib/icu/Collate: use CompareStringEx() on Windows | Max Kellermann | 2015-06-23 | 1 | -0/+26 |
| | |||||
* | lib/icu/Win32: wrappers for WideCharToMultiByte(), MultiByteToWideChar() | Max Kellermann | 2015-06-23 | 2 | -0/+98 |
| | |||||
* | lib/ffmpeg/Buffer: add "malloc" attribute | Max Kellermann | 2015-06-22 | 1 | -0/+1 |
| | |||||
* | *: doxygen fixups | Max Kellermann | 2015-03-17 | 1 | -5/+2 |
| | |||||
* | lib/upnp/Discovery: remove locking from ExpireDevices() | Max Kellermann | 2015-02-03 | 2 | -7/+6 |
| | |||||
* | lib/upnp/Discovery: apply naming convention | Max Kellermann | 2015-02-02 | 3 | -37/+37 |
| | |||||
* | Merge branch 'v0.19.x' | Max Kellermann | 2015-01-26 | 2 | -236/+0 |
|\ | |||||
| * | Merge branch 'v0.18.x' into v0.19.x | Max Kellermann | 2015-01-26 | 2 | -224/+0 |
| | | |||||
* | | config/Option: convert to strictly-typed enum | Max Kellermann | 2015-01-21 | 1 | -3/+3 |
| | | |||||
* | | Copyright year 2015 | Max Kellermann | 2015-01-01 | 77 | -77/+77 |
| | | |||||
* | | {mixer,output}/pulse: move code to LogPulseError() | Max Kellermann | 2014-12-29 | 2 | -0/+61 |
| | | |||||
* | | output/pulse: move SetError() to lib/pulse/Error.cxx | Max Kellermann | 2014-12-29 | 2 | -0/+62 |
| | | |||||
* | | {mixer,output}/pulse: use a common Domain instance | Max Kellermann | 2014-12-29 | 2 | -0/+51 |
| | | |||||
* | | Merge branch 'v0.19.x' | Max Kellermann | 2014-12-26 | 1 | -0/+6 |
|\| | |||||
| * | fs/Traits, ...: work around -Wtautological-pointer-compare | Max Kellermann | 2014-12-26 | 1 | -0/+6 |
| | | | | | | | | New in clang 3.6. | ||||
* | | lib/ffmpeg/Buffer: always include libavutil/mem.h | Max Kellermann | 2014-12-26 | 1 | -2/+1 |
| | | | | | | | | Needed for av_free(). | ||||
* | | decoder/ffmpeg: move code to lib/ffmpeg/Init.cxx | Max Kellermann | 2014-12-21 | 2 | -0/+64 |
| | | |||||
* | | decoder/ffmpeg: move code to lib/ffmpeg/LogCallback.cxx | Max Kellermann | 2014-12-20 | 2 | -0/+96 |
| | | |||||
* | | decoder/ffmpeg: use AVStream::duration | Max Kellermann | 2014-12-19 | 1 | -0/+25 |
| | | | | | | | | | | Use the duration of the stream we're actually decoding - not the "global" attribute AVFormatContext::duration which may differ. | ||||
* | | lib/ffmpeg/Time: add API documentation | Max Kellermann | 2014-12-19 | 1 | -0/+9 |
| | | |||||
* | | decoder/ffmpeg: move code to lib/ffmpeg/Time.hxx | Max Kellermann | 2014-12-19 | 1 | -0/+76 |
| | | |||||
* | | decoder/ffmpeg: move code to class FfmpegBuffer | Max Kellermann | 2014-12-18 | 1 | -0/+73 |
| | | |||||
* | | decoder/ffmpeg: log detailed error message | Max Kellermann | 2014-12-18 | 2 | -0/+74 |
| | | |||||
* | | Merge branch 'v0.19.x' | Max Kellermann | 2014-12-15 | 5 | -24/+180 |
|\| | |||||
| * | storage/nfs: add timeout | Max Kellermann | 2014-12-15 | 2 | -3/+13 |
| | | |||||
| * | lib/nfs/Connection: unregister socket with SocketMonitor::Steal() | Max Kellermann | 2014-12-15 | 1 | -1/+1 |
| | | | | | | | | | | SocketMonitor::Cancel() does not actually unregister the socket; it only disables the event. | ||||
| * | lib/nfs/Connection: implement mount timeout | Max Kellermann | 2014-12-15 | 2 | -2/+31 |
| | | |||||
| * | lib/nfs/Connection: add debug flag "in_destroy" | Max Kellermann | 2014-12-15 | 2 | -0/+11 |
| | | |||||
| * | lib/nfs/Connection: add assertion | Max Kellermann | 2014-12-14 | 1 | -0/+2 |
| | | |||||
| * | lib/nfs/Connection: fix reconnect after mount failure | Max Kellermann | 2014-12-14 | 1 | -1/+1 |
| | | | | | | | | | | | | | | When mounting had not yet finished, SocketMonitor::IsDefined() was always false, due to the workaround at the beginning of the function that calls SocketMonitor::Steal(). This commit drops the IsDefined() check because it was never necessary and breaks reconnect. | ||||
| * | lib/nfs/Connection: fix typo in code comment | Max Kellermann | 2014-12-14 | 1 | -1/+1 |
| | | |||||
| * | lib/nfs/Connection: fix memory leak (and assertion failure) | Max Kellermann | 2014-12-14 | 3 | -0/+28 |
| | | | | | | | | | | | | | | | | | | | | | | nfs_destroy_context() will invoke all pending callbacks with err==-EINTR. In CancellableCallback::Callback(), this will invoke NfsConnection::DeferClose(), which however is only designed to be called from nfs_service(). In non-debug mode, this will leak memory because nfs_close_async() is never called. Workaround: before nfs_destroy_context(), invoke nfs_close_async() on all pending file handles. | ||||
| * | lib/nfs/Connection: move code to Service() | Max Kellermann | 2014-12-14 | 2 | -12/+28 |
| | | |||||
| * | lib/nfs/Connection: add assertions | Max Kellermann | 2014-12-14 | 1 | -0/+2 |
| | | |||||
| * | lib/nfs/Connection: move code to method InternalClose() | Max Kellermann | 2014-12-14 | 2 | -3/+17 |
| | | |||||
| * | lib/nfs/Connection: make in_service and in_event debug-only flags | Max Kellermann | 2014-12-14 | 2 | -0/+11 |
| | | |||||
| * | lib/nfs/Connection: fix crash while canceling a failing Open() | Max Kellermann | 2014-12-14 | 1 | -2/+4 |
| | | | | | | | | | | | | | | The method NfsConnection::CancellableCallback::Callback() will always invoke NfsConnection::Close() on the file handle, even if the void pointer is not a nfsfh. This can happen if the Open() was not successful, e.g. when the file does not exist. | ||||
| * | lib/nfs/Connection: add assertions | Max Kellermann | 2014-12-14 | 1 | -0/+31 |
| | | |||||
* | | sticker/Database: move code to BindFind() | Max Kellermann | 2014-12-12 | 1 | -0/+13 |
| | | |||||
* | | sticker/Database: use the Error library | Max Kellermann | 2014-12-12 | 1 | -24/+28 |
| | | |||||
* | | lib/sqlite/Util: add ExecuteModified() | Max Kellermann | 2014-12-12 | 1 | -0/+11 |
| | | |||||
* | | sticker/Database: add wrapper for sqlite3_step() | Max Kellermann | 2014-12-12 | 1 | -0/+80 |
| | |