命名空间
变体
操作

std::experimental::filesystem::recursive_directory_iterator::disable_recursion_pending

来自 cppreference.com
 
 
实验性
技术规范
文件系统库 (文件系统 TS)
库基础 (库基础 TS)
库基础 2 (库基础 TS v2)
库基础 3 (库基础 TS v3)
并行扩展 (并行 TS)
并行扩展 2 (并行 TS v2)
并发扩展 (并发 TS)
并发扩展 2 (并发 TS v2)
概念 (概念 TS)
范围 (范围 TS)
反射 (反射 TS)
数学特殊函数 (特殊函数 TR)
实验性非 TS
模式匹配
线性代数
std::execution
契约
2D 图形
 
 
 
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';
 
        // do not descend into "b"
        if (i->path().filename() == "b")
            i.disable_recursion_pending();
    }
    fs::remove_all("sandbox");
}

输出

"sandbox/a"
 "sandbox/a/b"
"sandbox/syma" -> "a"

[编辑] 另请参阅

检查当前目录是否禁用了递归
(公共成员函数) [编辑]
前进到下一个条目
(公共成员函数) [编辑]