Namespaces
Variants

std::filesystem:: permissions

From cppreference.net
ヘッダーで定義 <filesystem>
void permissions ( const std:: filesystem :: path & p,

std:: filesystem :: perms prms,

std:: filesystem :: perm_options opts = perm_options :: replace ) ;
(1) (C++17以降)
void permissions ( const std:: filesystem :: path & p,

std:: filesystem :: perms prms,

std:: error_code & ec ) noexcept ;
(2) (C++17以降)
(3) (C++17以降)

p が解決するファイルのアクセス権限を変更します。POSIXの fchmodat と同様の動作です。 opts perm_options::nofollow が設定されていない限り、シンボリックリンクは追従されます。

2番目のシグネチャは、 opts perm_options :: replace に設定されているかのように動作します。

効果は以下のように prms および opts に依存します:

  • opts perm_options :: replace の場合、ファイル権限は正確に prms & std:: filesystem :: perms :: mask に設定されます(つまり、 prms のすべての有効なビットが適用されます)。
  • opts perm_options :: add の場合、ファイル権限は正確に status ( p ) . permissions ( ) | ( prms & perms :: mask ) に設定されます(つまり、 prms で設定されているがファイルの現在の権限にはない有効なビットが、ファイルの権限に追加されます)。
  • opts perm_options :: remove の場合、ファイル権限は正確に status ( p ) . permissions ( ) & ~ ( prms & perms :: mask ) に設定されます(つまり、 prms でクリアされているがファイルの現在の権限で設定されている有効なビットが、ファイルの権限からクリアされます)。

opts は、 replace add 、または remove のうちいずれか1つのみが設定されている必要があります。

例外を投げないオーバーロードは、エラー時に特別な動作をしません。

目次

パラメータ

p - 検査対象のパス
prms - 設定・追加・削除するパーミッション
opts - 本関数の動作を制御するオプション
ec - 例外を送出しないオーバーロードでのエラー報告用出力パラメータ

戻り値

(なし)

例外

noexcept でマークされていないオーバーロードは、 メモリ確保に失敗した場合 std::bad_alloc をスローする可能性があります。

1) 基盤OS APIエラーが発生した場合 std::filesystem::filesystem_error をスローします。この例外は p を第一パス引数、OSエラーコードをエラーコード引数として構築されます。
2,3) 設定する std:: error_code & パラメータをOS APIエラーコードに(OS API呼び出しが失敗した場合)、そして実行する ec. clear ( ) (エラーが発生しなかった場合)。

注記

権限は必ずしもビットとして実装されるわけではありませんが、概念的にはそのように扱われます。

一部のパーミッションビットは一部のシステムで無視される可能性があり、一部のビットを変更すると自動的に他のビットが変更される場合があります(例:所有者/グループ/全ユーザーの区別がないプラットフォームでは、3つの書き込みビットのいずれかを設定すると、3つすべてが設定されます)。

#include <filesystem>
#include <fstream>
#include <iostream>
void demo_perms(std::filesystem::perms p)
{
    using std::filesystem::perms;
    auto show = [=](char op, perms perm)
    {
        std::cout << (perms::none == (perm & p) ? '-' : op);
    };
    show('r', perms::owner_read);
    show('w', perms::owner_write);
    show('x', perms::owner_exec);
    show('r', perms::group_read);
    show('w', perms::group_write);
    show('x', perms::group_exec);
    show('r', perms::others_read);
    show('w', perms::others_write);
    show('x', perms::others_exec);
    std::cout << '\n';
}
int main()
{
    std::ofstream("test.txt"); // create file
    std::cout << "Created file with permissions: ";
    demo_perms(std::filesystem::status("test.txt").permissions());
    std::filesystem::permissions(
        "test.txt",
        std::filesystem::perms::owner_all | std::filesystem::perms::group_all,
        std::filesystem::perm_options::add
    );
    std::cout << "After adding u+rwx and g+rwx:  ";
    demo_perms(std::filesystem::status("test.txt").permissions());
    std::filesystem::remove("test.txt");
}

出力例:

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

関連項目

(C++17)
ファイルシステムのパーミッションを識別する
(列挙型)
(C++17) (C++17)
ファイル属性を決定する
シンボリックリンクのターゲットをチェックしてファイル属性を決定する
(関数)