//===-- Implementation of twalk --------------------------------*- C++ -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #include "src/search/twalk.h" #include "hdr/types/posix_tnode.h" #include "src/__support/common.h" #include "src/__support/macros/config.h" #include "src/__support/macros/null_check.h" #include "src/__support/weak_avl.h" namespace LIBC_NAMESPACE_DECL { using Node = WeakAVLNode; LLVM_LIBC_FUNCTION(void, twalk, (const __llvm_libc_tnode *root, void (*action)(const __llvm_libc_tnode *, VISIT, int))) { if (!root) return; const Node *node = reinterpret_cast(root); LIBC_CRASH_ON_NULLPTR(action); Node::walk(node, [action](const Node *n, Node::WalkType type, int depth) { VISIT v = (type == Node::WalkType::PreOrder) ? preorder : (type == Node::WalkType::InOrder) ? postorder : (type == Node::WalkType::PostOrder) ? endorder : leaf; action(reinterpret_cast(n), v, depth); }); } } // namespace LIBC_NAMESPACE_DECL