| Commit message (Collapse) | Author | Age | Files | Lines |
|
|
|
| |
Fixes bogus assertion failure.
|
|
|
|
|
| |
SocketMonitor::Cancel() does not actually unregister the socket; it
only disables the event.
|
| |
|
| |
|
| |
|
|
|
|
|
|
|
| |
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.
|
| |
|
|
|
|
|
|
|
|
|
|
|
| |
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.
|
| |
|
| |
|
| |
|
| |
|
|
|
|
|
|
|
| |
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.
|
| |
|
| |
|
|
|
|
|
|
| |
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.
|
| |
|
|
|
|
|
|
|
|
| |
Skipping those songs silently will confuse the client, because
commands specifying the song index within a playlist
(e.g. playlistdelete) will be out of sync.
This copies spl_print()'s behavior to playlist_file_print().
|
|\ |
|
| |
| |
| |
| |
| |
| | |
Version 2.5 fixed an API oddity, however it broke API compatibility,
at least with C++. Disable the workaround when a libavformat version
is detected that is recent enough.
|
| |
| |
| |
| |
| |
| | |
The "::" to explicitly refer to the global namespace appeared like a
good idea in C++, but it breaks with C libraries that implement
standard functions using macros (e.g. musl).
|
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| | |
There are code paths (mostly error cases) in which it is possible to
initialize an AudioOutput and then kill it without ever calling
audio_output_new(). In such a case, its destructor will attempt to
free a mixer that was never initialized, leading to an attempt to
take out a lock on a mutex that was similarly never initialized,
which hangs forever.
Fix by always initializing the mixer appropriately.
|
|\| |
|
| |
| |
| |
| |
| | |
Set the Error when zzip_seek()==-1 and not on success. Fixes a crash
after seeking.
|
| |
| |
| |
| |
| | |
Avoids crash because Close() invokes a call on a destructed
NfsConnection.
|
| | |
|
| |
| |
| |
| |
| | |
Avoid calling NfsConnection::RemoveLease(), because the lease has been
removed already.
|
| |
| |
| |
| |
| |
| | |
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.
|
| |
| |
| |
| |
| | |
Avoids a crash that occurs when NfsConnection::OnSocketReady()
dereferences itself before returning.
|
| |
| |
| |
| |
| |
| | |
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.
|
| |
| |
| |
| |
| | |
Fixes potential second mount attempt after the old connection to the
NFS server was shut down.
|
| | |
|
| |
| |
| |
| |
| |
| |
| |
| |
| | |
libmp4v2 is licensed under MPL 1.1, which is incompatible with GPLv2.
Unfortunately, this means that we must remove the plugin.
More information can be found in the Debian bug report:
http://bugs.debian.org/767504
|
| | |
|
| | |
|
| | |
|
|\| |
|
| |
| |
| |
| |
| | |
A negative uid value means it's not a "local socket" (PF_LOCAL).
uid==0 means user "root" connected.
|
| |
| |
| |
| | |
Must return -1 on error, not 0. 0 is root.
|
| | |
|
| | |
|
| | |
|
| | |
|
| | |
|
| | |
|
| | |
|
| | |
|
| |
| |
| |
| | |
Check opus_decoder!=nullptr instead.
|
| | |
|
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| | |
Commit d42c0f1dc5063d50a62817b63a1c2a4507c46071 added an OS X-specific
method of calling mpd_main_after_fork(), which uses Grand Central
Dispatch. Since this uses a block literal, it breaks compilation on
compilers which don't support the block extension, e.g. non-Apple
compilers. This affects users on older OS X releases with GCD (which
depend on older Clang releases, or Apple GCCs, which don't support the
C++11 features MPD needs); or which don't support GCD at all (10.5 and
lower).
This patch changes the #ifdef so that the non-GCD code is used
as it was on OS X before this patch if blocks aren't available, via
checking __BLOCKS__ macro.
|