path-permission

Crates.iopath-permission
lib.rspath-permission
version0.1.2
sourcesrc
created_at2021-07-03 16:00:33.365265
updated_at2021-07-07 09:11:02.469224
descriptionRust Path trait to get the permission.
homepage
repositoryhttps://github.com/CC2130/path-permission
max_upload_size
id418254
size11,102
Jia Chao (jiachao2130)

documentation

README

Path Permission

在已有一个确定的路径时,可依此库来获取路径文件的权限。 它为Path(Buf)提供了一个名为PathPermission的特性(trait),在使用Path类型 时,可以此获取其文件权限,是否可读(r)、可写(w)、可执行(x)。
目前只支持 Unix 类系统。

示例

use std::path::Path;

extern crate path_permission;

use path_permission::*;

let path = Path::new("src/lib.rs");

assert_eq!(path.is_readable().unwrap(), true);
assert_eq!(path.is_writable().unwrap(), true);
assert_eq!(path.is_excutable().unwrap(), false);
assert_eq!(path.is_removable().unwrap(), true);

assert_eq!(path.check_access(0o644).unwrap(), true);
assert_eq!(path.get_access().unwrap(), "0644");

assert_eq!(path.chmod(0o640).unwrap(), true);
// 注意,这里已经格式化为字符串
assert_eq!(path.get_access().unwrap(), "0640");
assert_eq!(path.chmod(0o644).unwrap(), true);

let new_path = Path::new("a/b/d/e/f");

assert_eq!(new_path.is_creatable().unwrap(), true);

注意

在使用时需注意:

  • 当返回值为Ok(false)时,意为无查看此路径的权限,即可能此路径不存在(从起始 路径开始,至无访问权限的子级路径,是存在的)。
  • 如无必须,不太建议使用相对路径,可使用 path-calculate将路径转换为绝对路径。
  • get_access() 所返回的权限已被格式化为字符串。

后续计划

计划支持 rwx 字符串输出、权限变更方法。

感谢

此项目部分代码,来源自项目permissions

Commit count: 4

cargo fmt