Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improve docstrings for filesize and stat #56244

Merged
Merged
Changes from 19 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
153 changes: 117 additions & 36 deletions base/stat.jl
Original file line number Diff line number Diff line change
Expand Up @@ -28,8 +28,15 @@ export
"""
StatStruct

A struct which stores the information from `stat`.
The following fields of this struct is considered public API:
A struct which stores information about a file. Usually
constructed by calling [`stat`](@ref) on a path.

This struct is used internally as the foundation of a number of utility
functions. Some return specific parts of the information stored in it
directly, such as [`filesize`](@ref), [`mtime`](@ref) and [`ctime`](@ref). Others add
some logic on top using bit-manipulation, such as [`isfifo`](@ref), [`ischardev`](@ref), and [`issetuid`](@ref).

The following fields of this struct are considered public API:

| Name | Type | Description |
|:--------|:--------------------------------|:-------------------------------------------------------------------|
Expand Down Expand Up @@ -200,10 +207,12 @@ if RawFD !== OS_HANDLE
end

"""
stat(file)
stat(joinpath...)
stat(path)
stat(path_elements...)

Return a structure whose fields contain information about the file.
If multiple arguments are given, they are joined by [`joinpath`](@ref).

The fields of the structure are:

| Name | Type | Description |
Expand All @@ -226,13 +235,14 @@ stat(path) = (path2 = joinpath(path); path2 isa typeof(path) ? error("stat not i
stat(path...) = stat(joinpath(path...))

"""
lstat(file)
lstat(joinpath...)
lstat(path)
lstat(path_elements...)

Like [`stat`](@ref), but for symbolic links gets the info for the link
itself rather than the file it refers to.
This function must be called on a file path rather than a file object or a file
descriptor.
Like [`stat`](@ref), but for symbolic links gets the info
for the link itself rather than the file it refers to.

This function must be called on a file path rather
than a file object or a file descriptor.
"""
lstat(path) = (path2 = joinpath(path); path2 isa typeof(path) ? error("lstat not implemented for $(typeof(path))") : lstat(path2))
lstat(path...) = lstat(joinpath(path...))
Expand Down Expand Up @@ -285,9 +295,14 @@ const filemode_table = (
)

"""
filemode(file)
filemode(path)
filemode(path_elements...)
filemode(stat_struct)

Return the mode of the file located at `path`,
or the mode indicated by the file descriptor `stat_struct`.

Equivalent to `stat(file).mode`.
Equivalent to `stat(path).mode` or `stat_struct.mode`.
"""
filemode(st::StatStruct) = st.mode
filemode_string(st::StatStruct) = filemode_string(st.mode)
Expand All @@ -308,33 +323,50 @@ function filemode_string(mode)
end

"""
filesize(path...)
filesize(path)
filesize(path_elements...)
filesize(stat_struct)

Return the size of the file located at `path`,
or the size indicated by file descriptor `stat_struct`.

Equivalent to `stat(file).size`.
Equivalent to `stat(path).size` or `stat_struct.size`.
"""
filesize(st::StatStruct) = st.size

"""
mtime(file)
mtime(path)
mtime(path_elements...)
mtime(stat_struct)

Equivalent to `stat(file).mtime`.
Return the unix timestamp of when the file at `path` was last modified,
or the last modified timestamp indicated by the file descriptor `stat_struct`.

Equivalent to `stat(path).mtime` or `stat_struct.mtime`.
"""
mtime(st::StatStruct) = st.mtime

"""
ctime(file)
ctime(path)
ctime(path_elements...)
ctime(stat_struct)

Return the unix timestamp of when the metadata of the file at `path` was last modified,
or the last modified metadata timestamp indicated by the file descriptor `stat_struct`.

Equivalent to `stat(file).ctime`.
Equivalent to `stat(path).ctime` or `stat_struct.ctime`.
"""
ctime(st::StatStruct) = st.ctime

# mode type predicates

"""
ispath(path) -> Bool
ispath(path_elements...) -> Bool

Return `true` if a valid filesystem entity exists at `path`,
otherwise returns `false`.

This is the generalization of [`isfile`](@ref), [`isdir`](@ref) etc.
"""
ispath(st::StatStruct) = st.ioerrno == 0
Expand All @@ -351,22 +383,27 @@ ispath(path::AbstractString) = ispath(String(path))

"""
isfifo(path) -> Bool
isfifo(path_elements...) -> Bool
isfifo(stat_struct) -> Bool

Return `true` if `path` is a FIFO, `false` otherwise.
Return `true` if the file at `path` or file descriptor `stat_struct` is FIFO, `false` otherwise.
"""
isfifo(st::StatStruct) = filemode(st) & 0xf000 == 0x1000

"""
ischardev(path) -> Bool
ischardev(path_elements...) -> Bool
ischardev(stat_struct) -> Bool

Return `true` if `path` is a character device, `false` otherwise.
Return `true` if the path `path` or file descriptor `stat_struct` refer to a character device, `false` otherwise.
"""
ischardev(st::StatStruct) = filemode(st) & 0xf000 == 0x2000

"""
isdir(path) -> Bool
isdir(path_elements...) -> Bool

Return `true` if `path` is a directory, `false` otherwise.
Return `true` if `path` points to a directory, `false` otherwise.

# Examples
```jldoctest
Expand All @@ -383,15 +420,18 @@ isdir(st::StatStruct) = filemode(st) & 0xf000 == 0x4000

"""
isblockdev(path) -> Bool
isblockdev(path_elements...) -> Bool
isblockdev(stat_struct) -> Bool

Return `true` if `path` is a block device, `false` otherwise.
Return `true` if the path `path` or file descriptor `stat_struct` refer to a block device, `false` otherwise.
"""
isblockdev(st::StatStruct) = filemode(st) & 0xf000 == 0x6000

"""
isfile(path) -> Bool
isfile(path_elements...) -> Bool

Return `true` if `path` is a regular file, `false` otherwise.
Return `true` if `path` points to a regular file, `false` otherwise.

# Examples
```jldoctest
Expand All @@ -417,68 +457,108 @@ isfile(st::StatStruct) = filemode(st) & 0xf000 == 0x8000

"""
islink(path) -> Bool
islink(path_elements...) -> Bool

Return `true` if `path` is a symbolic link, `false` otherwise.
Return `true` if `path` points to a symbolic link, `false` otherwise.
"""
islink(st::StatStruct) = filemode(st) & 0xf000 == 0xa000

"""
issocket(path) -> Bool
issocket(path_elements...) -> Bool

Return `true` if `path` is a socket, `false` otherwise.
Return `true` if `path` points to a socket, `false` otherwise.
"""
issocket(st::StatStruct) = filemode(st) & 0xf000 == 0xc000

# mode permission predicates

"""
issetuid(path) -> Bool
issetuid(path_elements...) -> Bool
issetuid(stat_struct) -> Bool

Return `true` if `path` has the setuid flag set, `false` otherwise.
Return `true` if the file at `path` or file descriptor `stat_struct` have the setuid flag set, `false` otherwise.
"""
issetuid(st::StatStruct) = (filemode(st) & 0o4000) > 0

"""
issetgid(path) -> Bool
issetgid(path_elements...) -> Bool
issetgid(stat_struct) -> Bool

Return `true` if `path` has the setgid flag set, `false` otherwise.
Return `true` if the file at `path` or file descriptor `stat_struct` have the setgid flag set, `false` otherwise.
"""
issetgid(st::StatStruct) = (filemode(st) & 0o2000) > 0

"""
issticky(path) -> Bool
issticky(path_elements...) -> Bool
issticky(stat_struct) -> Bool

Return `true` if `path` has the sticky bit set, `false` otherwise.
Return `true` if the file at `path` or file descriptor `stat_struct` have the sticky bit set, `false` otherwise.
"""
issticky(st::StatStruct) = (filemode(st) & 0o1000) > 0

"""
uperm(file)
uperm(path)
uperm(path_elements...)
uperm(stat_struct)

Get the permissions of the owner of the file as a bitfield of
Return a bitfield of the owner permissions for the file at `path` or file descriptor `stat_struct`.

| Value | Description |
|:------|:-------------------|
| 01 | Execute Permission |
| 02 | Write Permission |
| 04 | Read Permission |

For allowed arguments, see [`stat`](@ref).
The fact that a bitfield is returned means that if the permission
is read+write, the bitfield is "110", which maps to the decimal
value of 0+2+4=6. This is reflected in the printing of the
returned `UInt8` value.

See also [`gperm`](@ref) and [`operm`](@ref).

```jldoctest
julia> touch("dummy_file") # Create test-file without contents;
LilithHafner marked this conversation as resolved.
Show resolved Hide resolved

julia> uperm("dummy_file")
0x06

julia> bitstring(ans)
"00000110"

julia> has_read_permission(path) = uperm(path) & 0b00000100 != 0; # Use bit mask to check specific bit

julia> has_read_permission("dummy_file")
true

julia> rm("dummy_file") # Clean up test-file
```
"""
uperm(st::StatStruct) = UInt8((filemode(st) >> 6) & 0x7)

"""
gperm(file)
gperm(path)
gperm(path_elements...)
gperm(stat_struct)

Like [`uperm`](@ref) but gets the permissions of the group owning the file.

See also [`operm`](@ref).
"""
gperm(st::StatStruct) = UInt8((filemode(st) >> 3) & 0x7)

"""
operm(file)
operm(path)
operm(path_elements...)
operm(stat_struct)

Like [`uperm`](@ref) but gets the permissions for people who neither own the
file nor are a member of the group owning the file.

Like [`uperm`](@ref) but gets the permissions for people who neither own the file nor are a member of
the group owning the file
See also [`gperm`](@ref).
"""
operm(st::StatStruct) = UInt8((filemode(st) ) & 0x7)

Expand Down Expand Up @@ -514,14 +594,15 @@ function samefile(a::StatStruct, b::StatStruct)
end

"""
samefile(path_a::AbstractString, path_b::AbstractString)
samefile(path_a, path_b)

Check if the paths `path_a` and `path_b` refer to the same existing file or directory.
"""
samefile(a::AbstractString, b::AbstractString) = samefile(stat(a), stat(b))

"""
ismount(path) -> Bool
ismount(path_elements...) -> Bool

Return `true` if `path` is a mount point, `false` otherwise.
"""
Expand Down