gStore/VSTree/VNode.h

75 lines
2.3 KiB
C++

/*
* VNode.h
*
* Created on: 2014-6-20
* Author: liyouhuan
*/
#ifndef VNODE_H_
#define VNODE_H_
#include <vector>
#include "../Signature/SigEntry.h"
#include"LRUCache.h"
#include<sstream>
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<VNode*>& _child_vec, const EntitySig _filter_sig, LRUCache& _nodeBuffer);
/* only used by leaf Node */
bool retrieveEntry(std::vector<SigEntry>& _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_ */