std::experimental::filesystem::recursive_directory_iterator:: disable_recursion_pending
|
void
disable_recursion_pending
(
)
;
|
(ファイルシステム TS) | |
現在参照されているサブディレクトリがある場合、そのサブディレクトリへの再帰を無効にします。
この呼び出しは、イテレータの保留中の再帰フラグを次のように変更します。次に increment が呼び出されたとき、イテレータは現在サブディレクトリを参照している場合でも、未訪問の状態であれば現在のディレクトリ内で進行します。
保留中の再帰フラグの状態は、 recursion_pending() で問い合わせることができます。この呼び出し後は false となります。 increment の後には true にリセットされ、初期値も同様に true です。
* this が終端イテレータの場合、動作は未定義です。
目次 |
パラメータ
(なし)
戻り値
(なし)
例外
実装定義の例外をスローする可能性があります。
例
#include <experimental/filesystem> #include <fstream> #include <iostream> #include <string> namespace fs = std::experimental::filesystem; int main() { fs::create_directories("sandbox/a/b/c"); fs::create_directories("sandbox/a/b/d/e"); std::ofstream("sandbox/a/b/file1.txt"); fs::create_symlink("a", "sandbox/syma"); for (auto i = fs::recursive_directory_iterator("sandbox"); i != fs::recursive_directory_iterator(); ++i) { std::cout << std::string(i.depth(), ' ') << *i; if (fs::is_symlink(i->symlink_status())) std::cout << " -> " << fs::read_symlink(*i); std::cout << '\n'; // "b" ディレクトリ以下は探索しない if (i->path().filename() == "b") i.disable_recursion_pending(); } fs::remove_all("sandbox"); }
出力:
"sandbox/a" "sandbox/a/b" "sandbox/syma" -> "a"
関連項目
|
現在のディレクトリに対する再帰が無効かどうかをチェックする
(公開メンバ関数) |
|
|
次のエントリに進む
(公開メンバ関数) |