std::filesystem::recursive_directory_iterator:: depth
From cppreference.net
<
cpp
|
filesystem
|
recursive directory iterator
C++
std::filesystem::recursive_directory_iterator
| Member functions | ||||
|
recursive_directory_iterator::depth
|
||||
| Non-member functions | ||||
|
int
depth
(
)
const
;
|
(C++17以降) | |
開始ディレクトリから現在反復中のディレクトリまでのディレクトリ数を返します。つまり、ディレクトリ階層の現在の深さを示します。
開始ディレクトリの深さは 0 であり、そのサブディレクトリの深さは 1 となります。
* this が終端イテレータの場合、動作は未定義です。
目次 |
パラメータ
(なし)
戻り値
ディレクトリ階層の現在の深さ。
例外
例外を送出しません。
例
この例では、ディレクトリツリーの出力におけるインデントを計算するために反復深度を使用しています。
このコードを実行
#include <filesystem> #include <fstream> #include <iostream> #include <string> namespace fs = std::filesystem; int main() { fs::current_path(fs::temp_directory_path()); 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() << 1, ' ') << *i; if (fs::is_symlink(i->symlink_status())) std::cout << " -> " << fs::read_symlink(*i); std::cout << '\n'; } fs::remove_all("sandbox"); }
出力:
"sandbox/syma" -> "a"
"sandbox/a"
"sandbox/a/b"
"sandbox/a/b/d"
"sandbox/a/b/d/e"
"sandbox/a/b/file1.txt"
"sandbox/a/b/c"