Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | lib/nfs/FileReader: update "state" in OnNfsError() | Max Kellermann | 2014-11-25 | 1 | -0/+24 |
| | | | | | | Clean up the "state" to indicate that there is no longer any asynchronous operation. Fixes another NFS-related crash due to cleanup of a non-existing asynchronous operation. | ||||
* | lib/nfs/Manager: defer NfsConnection destruction | Max Kellermann | 2014-11-25 | 2 | -9/+54 |
| | | | | | Avoids a crash that occurs when NfsConnection::OnSocketReady() dereferences itself before returning. | ||||
* | lib/nfs/Connection: broadcast error before closing connection | Max Kellermann | 2014-11-25 | 1 | -4/+4 |
| | | | | | | During the NfsLease::OnNfsConnectionFailed() call, the old (defunct) nfs_context may be used to close file handles. Such code does not yet exist, but will be added soon to fix other bugs. | ||||
* | lib/nfs/Connection: cancel DeferredMonitor on disconnect | Max Kellermann | 2014-11-25 | 1 | -0/+4 |
| | | | | | Fixes potential second mount attempt after the old connection to the NFS server was shut down. | ||||
* | lib/nfs/FileReader: include Compiler.h for "final" fallback | Max Kellermann | 2014-11-25 | 1 | -0/+1 |
| | |||||
* | lib/upnp/ContentDirectoryService: swap uri_apply_base() parameters | Max Kellermann | 2014-11-07 | 1 | -1/+1 |
| | | | | | | When uri_apply_base() was moved from db/upnp/Util.cpp to util/UriUtil.cpp, the parameter order was changed, however without swapping the parameters in the ContentDirectoryService constructor. | ||||
* | lib/upnp/Discovery: add missing stdlib.h include | Max Kellermann | 2014-11-02 | 1 | -0/+1 |
| | |||||
* | db/upnp/Util: move caturl() to util/UriUtil.cxx | Max Kellermann | 2014-10-10 | 3 | -32/+2 |
| | |||||
* | storage/nfs: use the libnfs async API | Max Kellermann | 2014-10-09 | 2 | -0/+169 |
| | | | | Share the NFS connection with the NFS input plugin. | ||||
* | lib/nfs/Connection: reduce Error instance allocations | Max Kellermann | 2014-10-09 | 1 | -3/+2 |
| | |||||
* | lib/nfs/Glue: add assertion | Max Kellermann | 2014-10-09 | 1 | -0/+1 |
| | |||||
* | lib/nfs/Connection: add methods {Open,Read,Close}Directory() | Max Kellermann | 2014-10-07 | 2 | -0/+53 |
| | |||||
* | lib/nfs/Connection: add method Stat(path) | Max Kellermann | 2014-10-07 | 2 | -0/+33 |
| | |||||
* | lib/nfs/Connection: make GetEventLoop() public | Max Kellermann | 2014-10-06 | 1 | -4/+4 |
| | |||||
* | lib/nfs/Base: kludge to reduce number of NFS mounts | Max Kellermann | 2014-10-05 | 3 | -7/+124 |
| | | | | | | | Creating a NfsStorage sets its own export_name as the "base". Now NfsFileReader can use this information to derive the export_name to be mounted, instead of guessing. This solves the "too many connection" problem on the NFS server while updating the database. | ||||
* | lib/nfs/FileReader: postpone the nfs_close_async() call | Max Kellermann | 2014-10-01 | 4 | -6/+92 |
| | | | | | | If an async opertion is in progress, nfs_close_async() will make libnfs crash because the RPC callback will dereference an object that was freed by nfs_close_async(). | ||||
* | lib/nfs/Connection: fix memory leak when cancelling Open() | Max Kellermann | 2014-10-01 | 2 | -5/+23 |
| | | | | Close the newly allocated file handle passed to the callback. | ||||
* | lib/nfs/Connection: remove Mutex | Max Kellermann | 2014-10-01 | 2 | -18/+12 |
| | | | | | All locks are currenly held from only a single thread (the IOThread) and thus we don't need the Mutex. | ||||
* | lib/nfs/Connection: add method GetEventLoop() | Max Kellermann | 2014-10-01 | 2 | -1/+5 |
| | |||||
* | lib/nfs/Connection: remove obsolete flag postponed_destroy | Max Kellermann | 2014-10-01 | 2 | -18/+2 |
| | |||||
* | lib/nfs/Connection: remove deprecated move constructor workaround | Max Kellermann | 2014-10-01 | 1 | -16/+0 |
| | | | | | Not used anymore because NfsManager now uses boost::intrusive::set instead of std::map. | ||||
* | lib/nfs/Manager: use boost::intrusive::map | Max Kellermann | 2014-10-01 | 2 | -37/+78 |
| | | | | | Reduce overhead for storing the key twice, and more overhead while looking up the connection to remove it after a failure. | ||||
* | lib/nfs/Glue: add assertion | Max Kellermann | 2014-10-01 | 1 | -0/+4 |
| | |||||
* | lib/nfs/Glue: destruct the NfsManager in the I/O thread | Max Kellermann | 2014-10-01 | 3 | -5/+8 |
| | | | | | This allows eliminating the indirection code from the NfsConnection destructor. | ||||
* | lib/nfs/Glue: eliminate class NfsGlue | Max Kellermann | 2014-10-01 | 1 | -17/+1 |
| | | | | It's just a useless wrapper for class NfsManager. | ||||
* | lib/nfs/Cancellable: use boost::intrusive::list | Max Kellermann | 2014-10-01 | 3 | -40/+18 |
| | | | | | Reduce Remove() overhead because we don't have to walk the list to find an iterator by reference. | ||||
* | nfs/Connection: check for disappearing libnfs socket | Max Kellermann | 2014-08-31 | 1 | -0/+18 |
| | |||||
* | nfs/Connection: use only BroadcastError() | Max Kellermann | 2014-08-31 | 1 | -4/+1 |
| | | | | | Since BroadcastError() calls BroadcastMountError(), there's no need to check mount_finished here. | ||||
* | nfs/Connection: nfs_get_fd() can return -1 | Max Kellermann | 2014-08-31 | 1 | -0/+3 |
| | | | | | While reconnecting to the NFS server, the socket is -1, because there is no socket. Fixes a potential crash (assertion failure). | ||||
* | nfs/Connection: use nfs_get_error() for mount error | Max Kellermann | 2014-08-31 | 1 | -2/+3 |
| | |||||
* | nfs/Connection: fix assertion failure | Max Kellermann | 2014-08-31 | 1 | -1/+3 |
| | |||||
* | *: add missing Compiler.h includes | Max Kellermann | 2014-08-30 | 2 | -0/+2 |
| | | | | Necessary for "final" on gcc 4.6. | ||||
* | Tag: use SignedSongTime for the song duration | Max Kellermann | 2014-08-29 | 1 | -1/+1 |
| | |||||
* | input/ffmpeg: use av_strerror() | Max Kellermann | 2014-08-18 | 2 | -0/+74 |
| | | | | Generate more detailed error messages. | ||||
* | {input,decoder}/ffmpeg: move ffmpeg_domain to lib/ffmpeg/Domain.cxx | Max Kellermann | 2014-08-18 | 2 | -0/+51 |
| | | | | Eliminate duplicate definition (in input plugin and decoder plugin). | ||||
* | icu: include strings.h for strcasecmp | François Revol | 2014-08-16 | 1 | -0/+1 |
| | | | | Again, POSIX says strcasecmp is not in string.h. | ||||
* | fs/io/GzipOutputStream,GunzipReader: move zlib_domain to src/lib/zlib/Domain.cxx | Max Kellermann | 2014-08-11 | 2 | -0/+51 |
| | |||||
* | lib/nfs/Connection: include poll.h | Max Kellermann | 2014-06-30 | 1 | -0/+2 |
| | |||||
* | lib/nfs/Manager: gcc 4.7 compatibility hack | Max Kellermann | 2014-06-17 | 3 | -0/+32 |
| | | | | std::map::emplace() is only available from gcc 4.8 on. | ||||
* | input/nfs: use the asynchronous libnfs API | Max Kellermann | 2014-06-17 | 11 | -0/+1398 |
| | | | | More robust and cancellable. | ||||
* | lib/icu/Init: call u_init() and u_cleanup() | Max Kellermann | 2014-06-10 | 1 | -0/+14 |
| | | | | Make valgrind happy. | ||||
* | lib/icu: add IcuInit(), IcuFinish() | Max Kellermann | 2014-06-10 | 3 | -8/+78 |
| | |||||
* | InputStream: "protect" attributes | Max Kellermann | 2014-05-12 | 1 | -1/+1 |
| | |||||
* | icu/Collate: use u_strFoldCase() instead of ucol_getSortKey() | Max Kellermann | 2014-05-12 | 1 | -10/+41 |
| | | | | Turns out ucol_getSortKey() does not what I thought it does. | ||||
* | icu/Collate: UCharFromUTF8() returns WritableBuffer<UChar> | Max Kellermann | 2014-05-12 | 1 | -19/+20 |
| | |||||
* | icu/Collate: initialize error_code | Max Kellermann | 2014-05-12 | 1 | -1/+1 |
| | | | | Fixes the broken "search" command. | ||||
* | InputStream: convert to class | Max Kellermann | 2014-05-11 | 1 | -1/+1 |
| | |||||
* | icu/Collate: fix memory leak in IcuCaseFold() | Max Kellermann | 2014-04-09 | 1 | -0/+1 |
| | |||||
* | icu/Collate: pass UErrorCode* to ucol_strcollUTF8() | Max Kellermann | 2014-02-24 | 1 | -1/+2 |
| | | | | Fixes crash after database update. | ||||
* | icu/Collate: initialize the error code before ucol_open() | Max Kellermann | 2014-02-24 | 1 | -1/+1 |
| | | | | Fixes initialization failure. |