Discussion:
Trash specification regarding bind mounts
Colomban Wendling
2014-09-23 16:08:12 UTC
Permalink
Hi,

As this bug report shows[1], the trash handling in GNOME is buggy on
bind mounts, because the behavior of GIO and GVFS is inconsistent:
GIO (responsible for trashing files) trashes files in the topmost parent
directory on the same device as the file to trash, where GVFS
(responsible for listing the trash contents) only looks for trashes in
non-internal non-bind mounts. This leads to disappearing trashed files.

It was suggested by GLib developer Ryan Lortie that "the spec[2] should
probably be made a bit more clear on what is expected in cases like
this. Might be worth raising this on the xdg-list to see what other
desktops think."

Indeed, the specification defines a "top directory" as "the directory
where a file system is mounted." In the case of bind mounts, it is
arguable that the mount point is not "a file system mount point" as it
may not be the only mount for this file system nor mount a file system
root. It would be good if the specification had a definition that could
apply unambiguously to bind mounts as well.

So how do you think trash should behave on bind mounts?

We have gathered basically three possible behavior in such cases:

1. Trash at the mount location, regardless of the file system root. This
is what GIO's g_file_trash() currently does.

2. Trash at the file system root. This has implementation issues, like
that a rename generally doesn't pass mount boundaries and trashing may
then involve a copy. Likewise, the file system root may not be
accessible for writing for an user even when the bind mount is.

3. Do not support trashing in such cases. This seems to currently be the
preferred behavior for GIO maintainers.

In my opinion, the expected behavior from an user point of view would be
to follow solution 1 and trash at the mount location, regardless of
whether it is a file system root or a bind mount.

Thanks in advance for your advice,
Colomban

[1]: https://bugzilla.gnome.org/show_bug.cgi?id=604015
[2]: http://freedesktop.org/wiki/Specifications/trash-spec/
David Faure
2014-10-15 22:14:31 UTC
Permalink
Post by Colomban Wendling
1. Trash at the mount location, regardless of the file system root. This
is what GIO's g_file_trash() currently does.
2. Trash at the file system root. This has implementation issues, like
that a rename generally doesn't pass mount boundaries and trashing may
then involve a copy. Likewise, the file system root may not be
accessible for writing for an user even when the bind mount is.
3. Do not support trashing in such cases. This seems to currently be the
preferred behavior for GIO maintainers.
In my opinion, the expected behavior from an user point of view would be
to follow solution 1 and trash at the mount location, regardless of
whether it is a file system root or a bind mount.
Option 1 is fine with me.

It might be what my KDE code already does, since it doesn't do anything
special for bind mounts, but I'm too lazy to actually test that :-)
--
David Faure, ***@kde.org, http://www.davidfaure.fr
Working on KDE Frameworks 5
Loading...