std::filesystem:: permissions
|
ヘッダーで定義
<filesystem>
|
||
|
void
permissions
(
const
std::
filesystem
::
path
&
p,
std::
filesystem
::
perms
prms,
|
(1) | (C++17以降) |
|
void
permissions
(
const
std::
filesystem
::
path
&
p,
std::
filesystem
::
perms
prms,
|
(2) | (C++17以降) |
|
void
permissions
(
const
std::
filesystem
::
path
&
p,
std::
filesystem
::
perms
prms,
|
(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
をスローする可能性があります。
注記
権限は必ずしもビットとして実装されるわけではありませんが、概念的にはそのように扱われます。
一部のパーミッションビットは一部のシステムで無視される可能性があり、一部のビットを変更すると自動的に他のビットが変更される場合があります(例:所有者/グループ/全ユーザーの区別がないプラットフォームでは、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)
|
ファイル属性を決定する
シンボリックリンクのターゲットをチェックしてファイル属性を決定する (関数) |