命名空间
变体
操作

std::experimental::filesystem::permissions

来自 cppreference.com
< cpp‎ | experimental‎ | fs
 
 
实验性
技术规范
文件系统库 (文件系统 TS)
库基础 (库基础 TS)
库基础 2 (库基础 TS v2)
库基础 3 (库基础 TS v3)
并行扩展 (并行 TS)
并行扩展 2 (并行 TS v2)
并发扩展 (并发 TS)
并发扩展 2 (并发 TS v2)
概念 (概念 TS)
范围 (范围 TS)
反射 (反射 TS)
数学特殊函数 (特殊函数 TR)
实验性非 TS
模式匹配
线性代数
std::execution
契约
2D 图形
 
 
定义在头文件 <experimental/filesystem>
void permissions( const path& p, perms prms );
void permissions( const path& p, perms prms, error_code& ec );
(文件系统 TS)

更改 p 解析到的文件的访问权限,如同使用 POSIX fchmodat。如果设置了 prms::resolve_symlinks,则会跟随符号链接。

效果取决于 prms,如下所示

  • 如果既没有设置 perms::add_perms 也没有设置 perms::remove_perms,则文件权限将被设置为完全等于 prms & fs::perms::mask(即,应用 prms 的每个有效位)。
  • 如果设置了 perms::add_perms,则文件权限将被设置为完全等于 status(p).permissions() | (prms & perms::mask)(即,在 prms 中设置的但不在文件当前权限中的任何有效位都将添加到文件的权限中)。
  • 如果设置了 perms::remove_perms,则文件权限将被设置为完全等于 status(p).permissions() & ~(prms & perms::mask)(即,在 prms 中清除的但在文件当前权限中设置的任何有效位都将在文件的权限中被清除)。
  • 如果同时设置了 perms::add_permsperms::remove_perms,则会发生错误。

不抛出异常的重载对错误没有特殊操作。

内容

[编辑] 参数

p - 要检查的路径
prms - 要设置、添加或删除的权限
ec - 不抛出异常的重载中用于错误报告的输出参数

[编辑] 返回值

(无)

[编辑] 异常

不带 error_code& 参数的重载在底层操作系统 API 错误上抛出 filesystem_error,并使用 p 作为第一个参数,操作系统错误代码作为错误代码参数进行构造。如果内存分配失败,可能会抛出 std::bad_alloc。带 error_code& 参数的重载如果操作系统 API 调用失败,则将其设置为操作系统 API 错误代码,如果未发生错误,则执行 ec.clear()。此重载具有
noexcept 规范:  
noexcept
  

[编辑] 备注

权限不一定是按位实现的,但从概念上讲,它们被视为位。

某些权限位在某些系统上可能被忽略,更改某些位可能会自动更改其他位(例如,在没有所有者/组/所有区分的平台上,设置三个写入位中的任何一个都会设置所有三个)。

[编辑] 示例

#include <bitset>
#include <experimental/filesystem>
#include <fstream>
#include <iostream>
namespace fs = std::experimental::filesystem;
 
void demo_perms(fs::perms p)
{
     std::cout << ((p & fs::perms::owner_read) != fs::perms::none ? "r" : "-")
               << ((p & fs::perms::owner_write) != fs::perms::none ? "w" : "-")
               << ((p & fs::perms::owner_exec) != fs::perms::none ? "x" : "-")
               << ((p & fs::perms::group_read) != fs::perms::none ? "r" : "-")
               << ((p & fs::perms::group_write) != fs::perms::none ? "w" : "-")
               << ((p & fs::perms::group_exec) != fs::perms::none ? "x" : "-")
               << ((p & fs::perms::others_read) != fs::perms::none ? "r" : "-")
               << ((p & fs::perms::others_write) != fs::perms::none ? "w" : "-")
               << ((p & fs::perms::others_exec) != fs::perms::none ? "x" : "-")
               << '\n';
}
 
int main()
{
    std::ofstream("test.txt"); // create file
 
    std::cout << "Created file with permissions: ";
    demo_perms(fs::status("test.txt").permissions());
 
    fs::permissions("test.txt", fs::perms::add_perms |
                                fs::perms::owner_all | fs::perms::group_all);
 
    std::cout << "After adding o+rwx and g+rwx:  ";
    demo_perms(fs::status("test.txt").permissions());
 
    fs::remove("test.txt");
}

可能的输出

Created file with permissions: rw-r--r--
After adding o+rwx and g+rwx:  rwxrwxr--

[编辑] 另请参阅

标识文件系统权限
(枚举) [编辑]
确定文件属性
确定文件属性,检查符号链接目标
(函数) [编辑]