mirror of
https://github.com/zeldaret/botw
synced 2026-05-23 06:54:18 -04:00
18c60323a9
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"
65 lines
1.8 KiB
C++
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_
|