Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
* | | | decoder/ffmpeg: remove unnecessary nullptr check for av_free() | Max Kellermann | 2014-12-19 | 1 | -2/+1 | |
| | | | ||||||
* | | | decoder/ffmpeg: use AVStream::duration | Max Kellermann | 2014-12-19 | 2 | -10/+31 | |
| | | | | | | | | | | | | | | | Use the duration of the stream we're actually decoding - not the "global" attribute AVFormatContext::duration which may differ. | |||||
* | | | decoder/ffmpeg: skip _scan_stream() if no audio stream was found | Max Kellermann | 2014-12-19 | 1 | -5/+9 | |
| | | | ||||||
* | | | decoder/ffmpeg: remove redundant audio stream check | Max Kellermann | 2014-12-19 | 1 | -3/+3 | |
| | | | ||||||
* | | | decoder/ffmpeg: use more references | Max Kellermann | 2014-12-19 | 1 | -16/+16 | |
| | | | ||||||
* | | | decoder/ffmpeg: merge avformat_close_input() calls | Max Kellermann | 2014-12-19 | 1 | -57/+63 | |
| | | | ||||||
* | | | 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 | 3 | -48/+83 | |
| | | | ||||||
* | | | decoder/ffmpeg: use av_free() instead of av_freep() | Max Kellermann | 2014-12-19 | 1 | -1/+1 | |
| | | | ||||||
* | | | decoder/ffmpeg: add API documentation | Max Kellermann | 2014-12-19 | 1 | -1/+5 | |
| | | | ||||||
* | | | decoder/ffmpeg: copy_interleave_frame() returns ConstBuffer | Max Kellermann | 2014-12-18 | 1 | -12/+12 | |
| | | | ||||||
* | | | decoder/ffmpeg: copy_interleave_frame() returns Error | Max Kellermann | 2014-12-18 | 1 | -14/+22 | |
| | | | ||||||
* | | | decoder/ffmpeg: pass AVPacket copy to ffmpeg_send_packet() | Max Kellermann | 2014-12-18 | 1 | -7/+5 | |
| | | | ||||||
* | | | decoder/ffmpeg: simplify ffmpeg_send_packet() | Max Kellermann | 2014-12-18 | 1 | -15/+15 | |
| | | | ||||||
* | | | decoder/ffmpeg: pass references instead of pointers | Max Kellermann | 2014-12-18 | 1 | -33/+33 | |
| | | | ||||||
* | | | decoder/ffmpeg: move code to class FfmpegBuffer | Max Kellermann | 2014-12-18 | 3 | -17/+84 | |
| | | | ||||||
* | | | decoder/ffmpeg: fix crash on out-of-memory | Max Kellermann | 2014-12-18 | 1 | -3/+7 | |
| | | | | | | | | | | | | Fixes regression by commit 7c8038e | |||||
* | | | decoder/ffmpeg: log detailed error message | Max Kellermann | 2014-12-18 | 4 | -2/+77 | |
| | | | ||||||
* | | | decoder/ffmpeg: remove obsolete comment | Max Kellermann | 2014-12-18 | 1 | -1/+0 | |
| | | | ||||||
* | | | decoder/ffmpeg: add "pure" attributes | Max Kellermann | 2014-12-18 | 1 | -1/+2 | |
| | | | ||||||
* | | | output/winmm: show detailed error messages | Max Kellermann | 2014-12-17 | 1 | -7/+18 | |
| | | | ||||||
* | | | output/winmm: show detailed error messages | Max Kellermann | 2014-12-17 | 0 | -0/+0 | |
| | | | ||||||
* | | | win32/build.py: add option "--64" for a x64 build | Max Kellermann | 2014-12-17 | 1 | -0/+4 | |
| | | | ||||||
* | | | {win32,android}/build.py: add the host triple to the lib paths | Max Kellermann | 2014-12-17 | 2 | -15/+18 | |
| | | | | | | | | | | | | Allow multiple targets to share a library directory tree. | |||||
* | | | Merge tag 'v0.19.7' | Max Kellermann | 2014-12-17 | 6 | -7/+30 | |
|\| | | ||||||
| * | | release v0.19.7 | Max Kellermann | 2014-12-17 | 1 | -1/+1 | |
| | | | ||||||
| * | | Merge tag 'v0.18.21' into v0.19.x | Max Kellermann | 2014-12-17 | 3 | -5/+17 | |
| |\| | ||||||
| | * | release v0.18.21 | Max Kellermann | 2014-12-17 | 1 | -1/+1 | |
| | | | ||||||
| | * | playlist/embcue: fix filename suffix detection | k44 | 2014-12-16 | 2 | -1/+3 | |
| | | | | | | | | | | | | | | | The definition of the playlist_plugin struct member of the embcue plugin was incorrect. | |||||
| | * | decoder/ffmpeg: detect and fix negative time stamps | Max Kellermann | 2014-12-15 | 2 | -4/+9 | |
| | | | | | | | | | | | | | | | Works around assertion failure due to something that appears to be a (minor) FFmpeg bug. | |||||
| | * | configure.ac: prepare for 0.18.21 | Max Kellermann | 2014-12-15 | 2 | -2/+4 | |
| | | | ||||||
| * | | LogBackend: force-flush stderr on WIN32 | Max Kellermann | 2014-12-17 | 1 | -0/+6 | |
| | | | | | | | | | | | | setvbuf() does not seem to have an effect on Windows. | |||||
| * | | LogInit: make stderr line-buffered | Max Kellermann | 2014-12-17 | 1 | -0/+3 | |
| | | | | | | | | | | | | | | | Make sure everything gets logged right away. No delays because stdio's buffer is not yet full. | |||||
| * | | util/HugeAllocator: enable MEM_COMMIT on Windows | Max Kellermann | 2014-12-17 | 1 | -1/+3 | |
| | | | | | | | | | | | | | | | Without MEM_COMMIT, the reserved address space is not accessible, and MPD crashes. | |||||
* | | | win32/build.py: remove unused variable "build_arch" | Max Kellermann | 2014-12-16 | 1 | -3/+0 | |
| | | | ||||||
* | | | Merge branch 'v0.19.x' | Max Kellermann | 2014-12-15 | 8 | -25/+190 | |
|\| | | ||||||
| * | | storage/nfs: add timeout | Max Kellermann | 2014-12-15 | 3 | -3/+15 | |
| | | | ||||||
| * | | storage/nfs: clear last_error in SetState() | Max Kellermann | 2014-12-15 | 1 | -0/+1 | |
| | | | | | | | | | | | | Fixes bogus assertion failure. | |||||
| * | | 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 | 3 | -2/+32 | |
| | | | ||||||
| * | | 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 | 2 | -1/+2 | |
| | | | | | | | | | | | | | | | | | | | | | 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 | 4 | -0/+29 | |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 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 | 2 | -2/+6 | |
| | | | | | | | | | | | | | | | | | | | | | 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. |