Namespaces
Variants

std::experimental::filesystem::recursive_directory_iterator:: depth

From cppreference.net
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"