storage/udisks2: use existing mount point if already mounted
Fixes the "org.freedesktop.UDisks2.Error.AlreadyMounted" error. Closes #485
This commit is contained in:
parent
0a3aee9d82
commit
bbaeea1ab7
@ -156,16 +156,27 @@ UdisksStorage::OnListReply(ODBus::Message reply) noexcept
|
|||||||
using namespace UDisks2;
|
using namespace UDisks2;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
ParseObjects(reply, [this](Object &&o) {
|
std::string mount_point;
|
||||||
|
|
||||||
|
ParseObjects(reply, [this, &mount_point](Object &&o) {
|
||||||
if (!o.IsId(id))
|
if (!o.IsId(id))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
dbus_path = std::move(o.path);
|
dbus_path = std::move(o.path);
|
||||||
|
mount_point = std::move(o.mount_point);
|
||||||
});
|
});
|
||||||
|
|
||||||
if (dbus_path.empty())
|
if (dbus_path.empty())
|
||||||
throw FormatRuntimeError("No such UDisks2 object: %s",
|
throw FormatRuntimeError("No such UDisks2 object: %s",
|
||||||
id.c_str());
|
id.c_str());
|
||||||
|
|
||||||
|
if (!mount_point.empty()) {
|
||||||
|
/* already mounted: don't attempt to mount
|
||||||
|
again, because this would result in
|
||||||
|
org.freedesktop.UDisks2.Error.AlreadyMounted */
|
||||||
|
LockSetMountPoint(mount_point.c_str());
|
||||||
|
return;
|
||||||
|
}
|
||||||
} catch (...) {
|
} catch (...) {
|
||||||
const std::lock_guard<Mutex> lock(mutex);
|
const std::lock_guard<Mutex> lock(mutex);
|
||||||
mount_error = std::current_exception();
|
mount_error = std::current_exception();
|
||||||
|
Loading…
Reference in New Issue
Block a user