1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
#[cfg(any(unix, target_os = "vxworks"))]
use crate::fs::PermissionsExt;
use std::{fs, io};
#[derive(Debug, Clone, Eq, PartialEq)]
pub struct Permissions {
pub(crate) readonly: bool,
#[cfg(any(unix, target_os = "vxworks"))]
pub(crate) ext: PermissionsExt,
}
impl Permissions {
#[inline]
pub fn from_std(std: fs::Permissions) -> Self {
Self {
readonly: std.readonly(),
#[cfg(any(unix, target_os = "vxworks"))]
ext: PermissionsExt::from_std(std),
}
}
#[inline]
pub fn into_std(self, file: &fs::File) -> io::Result<fs::Permissions> {
self._into_std(file)
}
#[cfg(unix)]
#[inline]
#[allow(clippy::unnecessary_wraps)]
fn _into_std(self, _file: &fs::File) -> io::Result<fs::Permissions> {
use std::os::unix::fs::PermissionsExt;
Ok(fs::Permissions::from_mode(self.ext.mode()))
}
#[cfg(windows)]
#[inline]
fn _into_std(self, file: &fs::File) -> io::Result<fs::Permissions> {
let mut permissions = file.metadata()?.permissions();
permissions.set_readonly(self.readonly());
Ok(permissions)
}
#[inline]
pub const fn readonly(&self) -> bool {
self.readonly
}
#[inline]
pub fn set_readonly(&mut self, readonly: bool) {
self.readonly = readonly;
#[cfg(any(unix, target_os = "vxworks"))]
self.ext.set_readonly(readonly);
}
}
#[cfg(unix)]
impl std::os::unix::fs::PermissionsExt for Permissions {
#[inline]
fn mode(&self) -> u32 {
self.ext.mode()
}
#[inline]
fn set_mode(&mut self, mode: u32) {
self.ext.set_mode(mode)
}
#[inline]
fn from_mode(mode: u32) -> Self {
Self {
readonly: PermissionsExt::readonly(mode as libc::mode_t),
ext: PermissionsExt::from_mode(mode),
}
}
}
#[cfg(target_os = "vxworks")]
impl std::os::unix::fs::PermissionsExt for Permissions {
#[inline]
fn mode(&self) -> u32 {
self.ext.mode()
}
#[inline]
fn set_mode(&mut self, mode: u32) {
self.ext.set_mode(mode)
}
#[inline]
fn from_mode(mode: u32) -> Self {
Self {
readonly: PermissionsExt::readonly(mode),
ext: PermissionsExt::from(mode),
}
}
}