std::experimental::filesystem::recursive_directory_iterator::depth
From cppreference.com
< cpp | experimental | fs | recursive directory iterator
| int depth() const; |
(filesystem TS) | |
現在のイテレータが指しているディレクトリ階層の深さを返します。これは、開始ディレクトリから現在のディレクトリまでのディレクトリ数です。
開始ディレクトリの深さは 0、そのサブディレクトリの深さは 1、というようになります。
もし *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'; } fs::remove_all("sandbox"); }
出力
"sandbox/a" "sandbox/a/b" "sandbox/a/b/c" "sandbox/a/b/d" "sandbox/a/b/d/e" "sandbox/a/b/file1.txt" "sandbox/syma" -> "a"