Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
| * | | 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. | |||||
* | | | Merge branch 'v0.19.x' | Max Kellermann | 2014-12-15 | 7 | -25/+183 | |
|\| | | ||||||
| * | | storage/nfs: add timeout | Max Kellermann | 2014-12-15 | 2 | -3/+13 | |
| | | | ||||||
| * | | 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 | 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. | |||||
| * | | event/Loop: read the "again" flag while holding mutex | Max Kellermann | 2014-12-14 | 1 | -1/+2 | |
| | | | ||||||
| * | | lib/nfs/Connection: add assertions | Max Kellermann | 2014-12-14 | 1 | -0/+31 | |
| | | | ||||||
* | | | input/nfs: include cleanup | Max Kellermann | 2014-12-14 | 1 | -4/+0 | |
| | | | ||||||
* | | | input/async: add API documentation | Max Kellermann | 2014-12-14 | 1 | -0/+4 | |
| | | | ||||||
* | | | sticker/Match: add inequality operators | Max Kellermann | 2014-12-12 | 3 | -0/+34 | |
| | | | ||||||
* | | | sticker/Match: add operator "EQUALS" | Max Kellermann | 2014-12-12 | 3 | -3/+32 | |
| | | | | | | | | | | | | | | | Mapped to "=" in the MPD protocol. This is the first operator, initially supporting value matches in the MPD protocol. | |||||
* | | | sticker/Song: add enum StickerOperator to sticker_song_find() | Max Kellermann | 2014-12-12 | 6 | -5/+59 | |
| | | | ||||||
* | | | sticker/Database: move code to BindFind() | Max Kellermann | 2014-12-12 | 2 | -8/+29 | |
| | | | ||||||
* | | | sticker/Database: use the Error library | Max Kellermann | 2014-12-12 | 7 | -83/+125 | |
| | | | ||||||
* | | | sticker/Database: always invoke sqlite3_reset() and sqlite3_clear_bindings() | Max Kellermann | 2014-12-12 | 1 | -4/+4 | |
| | | | ||||||
* | | | lib/sqlite/Util: add ExecuteModified() | Max Kellermann | 2014-12-12 | 2 | -14/+23 | |
| | | | ||||||
* | | | sticker/Database: add wrapper for sqlite3_step() | Max Kellermann | 2014-12-12 | 2 | -89/+95 | |
| | | | ||||||
* | | | sticker/Database: move SQLite helpers to lib/sqlite/Util.hxx | Max Kellermann | 2014-12-12 | 2 | -45/+81 | |
| | | | ||||||
* | | | lib/sqlite/Domain: add Domain instance for SQLite | Max Kellermann | 2014-12-12 | 3 | -5/+57 | |
| | | | | | | | | | | | | Replaces the sticker_domain for Error::domain. | |||||
* | | | sticker/Database: remove redundant sqlite3_reset() calls | Max Kellermann | 2014-12-12 | 1 | -14/+0 | |
| | | | | | | | | | | | | | | | Call sqlite3_reset() only after a sqlite3_stmt* has been used, not before. Assume it is already in reusable state. | |||||
* | | | sticker/Database: require SQLite 3.7.3 | Max Kellermann | 2014-12-12 | 1 | -4/+0 | |
| | | | | | | | | | | | | | | | | | | SQLite 3.7.3 is the version shipped in Debian Squeeze (oldstable); should be old enough to be the required version. Drop the compatibility #ifdef. | |||||
* | | | vorbiscomments: Remove support for non-standard "album artist" tags. | Rasmus Steinke | 2014-12-12 | 1 | -1/+0 | |
| | | | | | | | | | | | | | | | | | | | | | | | | MPD used both "album artist" and "albumartist" tags and mapped them to one tag. This could lead to issues, if a file had both tags, causing MPD to send a list of albumartists instead of a single one. Since "album artist" is not a standard tag anyway and even its originators started to use the proper alternative, its time to say goodbye! | |||||
* | | | sticker/Database: make variables more local | Max Kellermann | 2014-12-12 | 1 | -10/+8 | |
| | | | ||||||
* | | | sticker/Database: add sqlite3_bind_text() wrapper | Max Kellermann | 2014-12-12 | 1 | -112/+42 | |
| | | | ||||||
* | | | sticker/Database: remove C-style (void) | Max Kellermann | 2014-12-12 | 2 | -4/+4 | |
| | | | ||||||
* | | | Merge branch 'v0.19.x' | Max Kellermann | 2014-12-12 | 2 | -2/+3 | |
|\| | | ||||||
| * | | util/HugeAllocator: disable MEM_LARGE_PAGES on Windows | Max Kellermann | 2014-12-12 | 1 | -1/+2 | |
| | | | | | | | | | | | | | | | | | | MEM_LARGE_PAGES does not appear to work. Instead, MEM_RESERVE appears to be necessary. Until I figure this out, this large pages are disabled. | |||||
| * | | input/Init: eliminate double colon from log message | Max Kellermann | 2014-12-12 | 1 | -1/+1 | |
| | | | ||||||
* | | | decoder/ffpmeg: make variables more local | Max Kellermann | 2014-12-11 | 1 | -3/+2 | |
| | | | ||||||
* | | | decoder/ffpmeg: simplify ffmpeg_send_packet() | Max Kellermann | 2014-12-11 | 1 | -8/+8 | |
| | | | ||||||
* | | | decoder/ffmpeg: support stream tags | Max Kellermann | 2014-12-11 | 1 | -0/+39 | |
| | | | ||||||
* | | | decoder/ffpmeg: move code to FfmpegScanMetadata() | Max Kellermann | 2014-12-11 | 1 | -4/+18 | |
| | | | ||||||
* | | | decoder/ffmpeg: support ReplayGain and MixRamp | Max Kellermann | 2014-12-10 | 1 | -0/+56 | |
| | | | ||||||
* | | | decoder/ffpmeg: use forward declarations | Max Kellermann | 2014-12-10 | 2 | -9/+5 | |
| | | | ||||||
* | | | decoder/ffpmeg: rename functions to CamelCase | Max Kellermann | 2014-12-10 | 3 | -17/+17 | |
| | | | ||||||
* | | | decoder/ffmpeg: optimize ffmpeg_scan_dictionary() | Max Kellermann | 2014-12-10 | 1 | -7/+9 | |
| | | | | | | | | | | | | | | | Don't scan tag items if the handler doesn't implement the tag() method. | |||||
* | | | ReplayGainInfo: add method IsDefined() | Max Kellermann | 2014-12-10 | 1 | -0/+5 | |
| | | | ||||||
* | | | ReplayGainInfo: make IsDefined() constexpr | Max Kellermann | 2014-12-10 | 1 | -2/+1 | |
| | | | ||||||
* | | | Util/Manual: cast via void* to avoid alignment warnings | Max Kellermann | 2014-12-09 | 1 | -2/+4 | |
| | | |