1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
use super::get_path::concatenate;
use crate::fs::Permissions;
use std::path::Path;
use std::{fs, io};

/// *Unsandboxed* function similar to `set_permissions`, but which does not
/// perform sandboxing.
pub(crate) fn set_permissions_unchecked(
    start: &fs::File,
    path: &Path,
    perm: Permissions,
) -> io::Result<()> {
    // According to [Rust's documentation], `fs::set_permissions` uses
    // `SetFileAttributes`, and according to [Windows' documentation]
    // `SetFileAttributes` does not follow symbolic links.
    //
    // [Windows' documentation]: https://docs.microsoft.com/en-us/windows/win32/fileio/symbolic-link-effects-on-file-systems-functions#setfileattributes
    // [Rust's documentation]: https://doc.rust-lang.org/std/fs/fn.set_permissions.html#platform-specific-behavior
    let out_path = concatenate(start, path)?;
    fs::set_permissions(out_path, perm.into_std(start)?)
}