aboutsummaryrefslogtreecommitdiffstats
Commit message (Collapse)AuthorAgeFilesLines
* decoder/ffmpeg: remove unnecessary nullptr check for av_free()Max Kellermann2014-12-191-2/+1
|
* decoder/ffmpeg: use AVStream::durationMax Kellermann2014-12-192-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 foundMax Kellermann2014-12-191-5/+9
|
* decoder/ffmpeg: remove redundant audio stream checkMax Kellermann2014-12-191-3/+3
|
* decoder/ffmpeg: use more referencesMax Kellermann2014-12-191-16/+16
|
* decoder/ffmpeg: merge avformat_close_input() callsMax Kellermann2014-12-191-57/+63
|
* lib/ffmpeg/Time: add API documentationMax Kellermann2014-12-191-0/+9
|
* decoder/ffmpeg: move code to lib/ffmpeg/Time.hxxMax Kellermann2014-12-193-48/+83
|
* decoder/ffmpeg: use av_free() instead of av_freep()Max Kellermann2014-12-191-1/+1
|
* decoder/ffmpeg: add API documentationMax Kellermann2014-12-191-1/+5
|
* decoder/ffmpeg: copy_interleave_frame() returns ConstBufferMax Kellermann2014-12-181-12/+12
|
* decoder/ffmpeg: copy_interleave_frame() returns ErrorMax Kellermann2014-12-181-14/+22
|
* decoder/ffmpeg: pass AVPacket copy to ffmpeg_send_packet()Max Kellermann2014-12-181-7/+5
|
* decoder/ffmpeg: simplify ffmpeg_send_packet()Max Kellermann2014-12-181-15/+15
|
* decoder/ffmpeg: pass references instead of pointersMax Kellermann2014-12-181-33/+33
|
* decoder/ffmpeg: move code to class FfmpegBufferMax Kellermann2014-12-183-17/+84
|
* decoder/ffmpeg: fix crash on out-of-memoryMax Kellermann2014-12-181-3/+7
| | | | Fixes regression by commit 7c8038e
* decoder/ffmpeg: log detailed error messageMax Kellermann2014-12-184-2/+77
|
* decoder/ffmpeg: remove obsolete commentMax Kellermann2014-12-181-1/+0
|
* decoder/ffmpeg: add "pure" attributesMax Kellermann2014-12-181-1/+2
|
* output/winmm: show detailed error messagesMax Kellermann2014-12-171-7/+18
|
* output/winmm: show detailed error messagesMax Kellermann2014-12-170-0/+0
|
* win32/build.py: add option "--64" for a x64 buildMax Kellermann2014-12-171-0/+4
|
* {win32,android}/build.py: add the host triple to the lib pathsMax Kellermann2014-12-172-15/+18
| | | | Allow multiple targets to share a library directory tree.
* Merge tag 'v0.19.7'Max Kellermann2014-12-176-7/+30
|\
| * release v0.19.7Max Kellermann2014-12-171-1/+1
| |
| * Merge tag 'v0.18.21' into v0.19.xMax Kellermann2014-12-173-5/+17
| |\
| | * release v0.18.21Max Kellermann2014-12-171-1/+1
| | |
| | * playlist/embcue: fix filename suffix detectionk442014-12-162-1/+3
| | | | | | | | | | | | | | | The definition of the playlist_plugin struct member of the embcue plugin was incorrect.
| | * decoder/ffmpeg: detect and fix negative time stampsMax Kellermann2014-12-152-4/+9
| | | | | | | | | | | | | | | Works around assertion failure due to something that appears to be a (minor) FFmpeg bug.
| | * configure.ac: prepare for 0.18.21Max Kellermann2014-12-152-2/+4
| | |
| * | LogBackend: force-flush stderr on WIN32Max Kellermann2014-12-171-0/+6
| | | | | | | | | | | | setvbuf() does not seem to have an effect on Windows.
| * | LogInit: make stderr line-bufferedMax Kellermann2014-12-171-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 WindowsMax Kellermann2014-12-171-1/+3
| | | | | | | | | | | | | | | Without MEM_COMMIT, the reserved address space is not accessible, and MPD crashes.
* | | win32/build.py: remove unused variable "build_arch"Max Kellermann2014-12-161-3/+0
| | |
* | | Merge branch 'v0.19.x'Max Kellermann2014-12-158-25/+190
|\| |
| * | storage/nfs: add timeoutMax Kellermann2014-12-153-3/+15
| | |
| * | storage/nfs: clear last_error in SetState()Max Kellermann2014-12-151-0/+1
| | | | | | | | | | | | Fixes bogus assertion failure.
| * | lib/nfs/Connection: unregister socket with SocketMonitor::Steal()Max Kellermann2014-12-151-1/+1
| | | | | | | | | | | | | | | SocketMonitor::Cancel() does not actually unregister the socket; it only disables the event.
| * | lib/nfs/Connection: implement mount timeoutMax Kellermann2014-12-153-2/+32
| | |
| * | lib/nfs/Connection: add debug flag "in_destroy"Max Kellermann2014-12-152-0/+11
| | |
| * | lib/nfs/Connection: add assertionMax Kellermann2014-12-141-0/+2
| | |
| * | lib/nfs/Connection: fix reconnect after mount failureMax Kellermann2014-12-142-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 commentMax Kellermann2014-12-141-1/+1
| | |
| * | lib/nfs/Connection: fix memory leak (and assertion failure)Max Kellermann2014-12-144-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 Kellermann2014-12-142-12/+28
| | |
| * | lib/nfs/Connection: add assertionsMax Kellermann2014-12-141-0/+2
| | |
| * | lib/nfs/Connection: move code to method InternalClose()Max Kellermann2014-12-142-3/+17
| | |
| * | lib/nfs/Connection: make in_service and in_event debug-only flagsMax Kellermann2014-12-142-0/+11
| | |
| * | lib/nfs/Connection: fix crash while canceling a failing Open()Max Kellermann2014-12-142-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.