Files
botw/lib/sead/include/container/seadTreeNode.h
T
Léo Lam 18c60323a9 Switch to subrepos
git subrepo clone https://github.com/open-ead/sead lib/sead

subrepo:
  subdir:   "lib/sead"
  merged:   "1b66e825d"
upstream:
  origin:   "https://github.com/open-ead/sead"
  branch:   "master"
  commit:   "1b66e825d"
git-subrepo:
  version:  "0.4.3"
  origin:   "https://github.com/ingydotnet/git-subrepo"
  commit:   "2f68596"

git subrepo clone (merge) https://github.com/open-ead/nnheaders lib/NintendoSDK

subrepo:
  subdir:   "lib/NintendoSDK"
  merged:   "9ee21399f"
upstream:
  origin:   "https://github.com/open-ead/nnheaders"
  branch:   "master"
  commit:   "9ee21399f"
git-subrepo:
  version:  "0.4.3"
  origin:   "ssh://git@github.com/ingydotnet/git-subrepo"
  commit:   "2f68596"

git subrepo clone https://github.com/open-ead/agl lib/agl

subrepo:
  subdir:   "lib/agl"
  merged:   "7c063271b"
upstream:
  origin:   "https://github.com/open-ead/agl"
  branch:   "master"
  commit:   "7c063271b"
git-subrepo:
  version:  "0.4.3"
  origin:   "ssh://git@github.com/ingydotnet/git-subrepo"
  commit:   "2f68596"

git subrepo clone https://github.com/open-ead/EventFlow lib/EventFlow

subrepo:
  subdir:   "lib/EventFlow"
  merged:   "c35d21b34"
upstream:
  origin:   "https://github.com/open-ead/EventFlow"
  branch:   "master"
  commit:   "c35d21b34"
git-subrepo:
  version:  "0.4.3"
  origin:   "ssh://git@github.com/ingydotnet/git-subrepo"
  commit:   "2f68596"
2022-03-21 21:31:42 +01:00

65 lines
1.8 KiB
C++

#ifndef SEAD_TREENODE_H_
#define SEAD_TREENODE_H_
#include <basis/seadTypes.h>
namespace sead
{
class TreeNode
{
public:
TreeNode();
void clearLinks();
s32 countChildren() const;
void detachAll();
void detachSubTree();
TreeNode* findRoot();
const TreeNode* findRoot() const;
void insertAfterSelf(TreeNode* node);
void insertBeforeSelf(TreeNode* node);
void pushBackChild(TreeNode* node);
void pushBackSibling(TreeNode* node);
void pushFrontChild(TreeNode* node);
protected:
void clearChildLinksRecursively_();
TreeNode* mParent;
TreeNode* mChild;
TreeNode* mNext;
TreeNode* mPrev;
};
template <typename T>
class TTreeNode : public TreeNode
{
public:
TTreeNode() = default;
explicit TTreeNode(T data) : mData(data) {}
T& value() { return mData; }
const T& value() const { return mData; }
TTreeNode* parent() const { return static_cast<TTreeNode*>(mParent); }
TTreeNode* child() const { return static_cast<TTreeNode*>(mChild); }
TTreeNode* next() const { return static_cast<TTreeNode*>(mNext); }
TTreeNode* prev() const { return static_cast<TTreeNode*>(mPrev); }
TTreeNode* findRoot() { return static_cast<TTreeNode*>(TreeNode::findRoot()); }
const TTreeNode* findRoot() const { return static_cast<TTreeNode*>(TreeNode::findRoot()); }
void insertAfterSelf(TTreeNode* node) { TreeNode::insertAfterSelf(node); }
void insertBeforeSelf(TTreeNode* node) { TreeNode::insertBeforeSelf(node); }
void pushBackChild(TTreeNode* node) { TreeNode::pushBackChild(node); }
void pushBackSibling(TTreeNode* node) { TreeNode::pushBackSibling(node); }
void pushFrontChild(TTreeNode* node) { TreeNode::pushFrontChild(node); }
// TODO: probably iterators
protected:
T mData;
};
} // namespace sead
#endif // SEAD_TREENODE_H_