Description
@rustbot label C-discussion
Main tracking issue: #86442
Background
The io_error_more
feature introduced 21 new variants into ErrorKind
. They were FCP'd back in December 2022, but there appeared to be quite a lot of disagreement about 4 of the added variants, so the stabilization (#106375) got stalled for over twenty months. Thankfully, the 17 uncontroversial variants got stabilized in #128316, so now we just need to iron out a satisfactory design for the remaining 4 variants, and then they can be stabilized too.
In order to not block any of the remaining variants on each other and to not intertwine the discussions, I've created 4 separate issues, which summarize the concerns & suggestions voiced up until this point and can serve as a place for further discussion.
FilesystemLoop
: you are hereFilesystemQuotaExceeded
: [discussion]ErrorKind::FilesystemQuotaExceeded
fromio_error_more
#130190CrossesDevices
: [discussion]ErrorKind::CrossesDevices
fromio_error_more
#130191InvalidFilename
: [discussion]ErrorKind::InvalidFilename
fromio_error_more
#130192
FilesystemLoop
Currently corresponds to ELOOP
on Unix and nothing ERROR_CANT_RESOLVE_FILENAME
on Windows. (#86442 (comment), #130207)
Current docs description:
Loop in the filesystem or IO subsystem; often, too many levels of symbolic links.
There was a loop (or excessively long chain) resolving a filesystem object or file IO object.
On Unix this is usually the result of a symbolic link loop; or, of exceeding the system-specific limit on the depth of symlink traversal.
Make it correspond to ERROR_CANT_RESOLVE_FILENAME
on Windows
ERROR_CANT_RESOLVE_FILENAME
on WindowsDone in #130207
Old description
for
ELOOP
, Windows appears to givewinapi::shared::winerror::ERROR_CANT_RESOLVE_FILENAME
in similar situations (e.g. symlink loops). Could we add that in, or perhaps generaliseFileSystemLoop
to the slightly more general case of being unable to resolve?
Originally posted by Robert Collins in #86442 (comment)
In #86442 (comment) Ian Jackson voices a concern that this might not be the only place where ERROR_CANT_RESOLVE_FILENAME
appears.
Chris Denton in #86442 (comment) and Robert Collins in #86442 (comment) confirm that this is the only place where Windows currently gives ERROR_CANT_RESOLVE_FILENAME
and that there is a good correspondence with Unix's ELOOP
(when it comes to symlikns, see below for the other usages of ELOOP
).
Ian Jackson agrees with them in #106375 (comment), but proposes this should be done separately from stabilization.
There seems to be a consensus regarding this point.
Bikshed the name: be about loops in general, drop "filesystem" from the name
Unix's ELOOP
is not just for symlink loops (or too long symlink chains).
ELOOP itself isn't returned solely when loops are detected. Add to that list mount(2) returning ELOOP for move operations where the
target
is a child of thesource
- something that has absolutely nothing to do with symlinks, andexecve
returning ELOOP for exceeding recursion limits during recursive script execution (since Linux 3.8).
- because OS errors are moving targets, we cannot assume Linux / BSD / others will not introduce a 5th or 6th meaning, and its clear to me at least that Linux doesn't treat ELOOP as a filesystem error but a more general error.
I suggest renaming it to
LoopError
, but document that it means ELOOP on Linux andERROR_CANT_RESOLVE_FILENAME
on Windows, and either describe what we know right now, or provide breadcrumbs for readers to catch up.
Originally posted by Robert Collins in #86442 (comment)
I have a mild preference for renaming
FilesystemLoop
to something that doesn't includeFilesystem
, for the same reason: OSes do use it for other errors. For instance, Linux also uses it for keyrings, BPF, network routing/filtering, vhost, and network bridges.
Originally posted by Josh Triplett in #106375 (comment)
I disagree with renaming
FilesystemLoop
.It is true that Unix has a tendency to reuse errno values, so that any particular errno value can often mean a variety of things. Particularly, less-common (even, obscure) APIs and facilities (ab)use errno values. Attempting to represent all these obscure possibilities leads to descriptions and categorisations that are vague and overlapping. We generally haven't done that and I don't think we should start now. (All of this was discussed at length in the earlier conversations in the tracking issue.)
The APIs available in std will produce this error for filesystem operations, not obscure other purposes. I think calling it
FilesystemLoop
is sensible.
Originally posted by Ian Jackson in #106375 (comment)
Bikeshed the name: be about symlink resolution failure in general, stop mentioning loops
some system calls on Linux also use
ELOOP
to mean "ELOOP A loop exists in symbolic links encountered during resolution of the path argument, or O_NOFOLLOW was specified and the path argument names a symbolic link." so I think interpreting it as "symlink loop or similar symlink resolve error was encountered" might be an accurate description, although (bike-shedding!) I don't know ifFilesystemLoop
is an accurate name then, and not something likeSymlinkResolutionFailed
or such...
Originally posted by Alain Emilia Anna Zscheile in #86442 (comment)