namespace std::filesystem {
bool is_character_file(file_status s) noexcept; // (1)
bool is_character_file(const path& p); // (2)
bool is_character_file(const path& p, std::error_code& ec) noexcept; // (3)
}
概要
指定されたパスがキャラクタデバイスのスペシャルファイルを指しているかを確認する。
Linux環境においては、/dev/null
、/dev/urandom
、/dev/zero
などがキャラクタデバイスに該当する。
戻り値
- (1) :
return s.type() == file_type::character;
- (2) :
return is_character_file(status(p));
- (3) :
file_status s = status(p, ec); if (ec) { return false; } // ファイルが見つからなかったらエラー file_type type = s.type(); if (type == file_type::none || file_type::not_found || file_type::unknown) { ec = implementation-defined; return false; } ec.clear(); return is_character_file(s);
例外
- (1) : 投げない
- (2) : ファイルシステムがエラーを報告する場合がある。それに加えて、指定されたファイルの種別が
file_type::none
、file_type::not_found
、file_type::unknown
のいずれかである場合もエラーである。エラーが発生した場合は、std::filesystem::filesystem_error
例外を送出する - (3) : 投げない
例
Linux環境の例
#include <cassert>
#include <filesystem>
namespace fs = std::filesystem;
int main()
{
// (1)
// 取得済みのファイル状態を使用して、キャラクタスペシャルファイルかを確認
assert(fs::is_character_file(fs::status("/dev/null")));
// (2)
// パスを指定して、キャラクタスペシャルファイルかを確認。
assert(fs::is_character_file("/dev/null"));
assert(fs::is_character_file("/dev/urandom"));
assert(fs::is_character_file("/dev/zero"));
// (3)
// エラー情報を例外ではなくerror_codeで受け取る
std::error_code ec;
bool result = fs::is_character_file("/dev/null", ec);
assert(!ec);
assert(result);
}
出力
バージョン
言語
- C++17
処理系
- Clang: 7.0 ✅
- GCC: 8.1 ✅
- Visual C++: