/* * VNode.h * * Created on: 2014-6-20 * Author: liyouhuan */ #ifndef VNODE_H_ #define VNODE_H_ #include #include "../Signature/SigEntry.h" #include"LRUCache.h" #include class VNode{ public: static const int MAX_CHILD_NUM = 151; static const int MIN_CHILD_NUM = 60; //debug // static const int MAX_CHILD_NUM = 50; // static const int MIN_CHILD_NUM = 20; VNode(); bool isLeaf()const; bool isRoot()const; bool isFull()const; void setAsLeaf(bool _isLeaf); void setAsRoot(bool _isRoot); int getChildNum()const; int getFileLine()const; int getFatherFileLine()const; int getChildFileLine(int _i)const; void setChildNum(int _num); void setFileLine(int _line); void setFatherFileLine(int _line); void setChildFileLine(int _i, int _line); const SigEntry& getEntry()const; const SigEntry& getChildEntry(int _i)const; void setEntry(const SigEntry _entry); void setChildEntry(int _i, const SigEntry _entry); VNode* getFather(LRUCache& _nodeBuffer)const; // get the father node's pointer. VNode* getChild(int _i, LRUCache& _nodeBuffer)const; // get the _i-th child node's pointer. /* add one child node to this node. when splitting this node, can add a new child to it. */ bool addChildNode(VNode* _p_child_node, bool _is_splitting = false); /* add one child entry to this node. when splitting this node, can add a new entry to it. */ bool addChildEntry(const SigEntry _entry, bool _is_splitting = false); bool removeChild(int _i); int getIndexInFatherNode(LRUCache& _nodeBuffer); void refreshSignature(); // just refresh itself signature. void refreshAncestorSignature(LRUCache& _nodeBuffer); // refresh self and its ancestor's signature. /* used by internal Node */ bool retrieveChild(std::vector& _child_vec, const EntitySig _filter_sig, LRUCache& _nodeBuffer); /* only used by leaf Node */ bool retrieveEntry(std::vector& _entry_vec, const EntitySig _filter_sig, LRUCache& _nodeBuffer); /* for debug */ bool checkState(); std::string to_str(); private: bool is_leaf; bool is_root; int child_num; int self_file_line; int father_file_line; SigEntry entry; SigEntry child_entries[VNode::MAX_CHILD_NUM]; int child_file_lines[VNode::MAX_CHILD_NUM]; }; #endif /* VNODE_H_ */