if ((*data) == (*(*it))) {
BTreeData *aborrar = (*it);
node_keys.erase (it);
+ deleted_block_data.push_back (aborrar->GetKey ()->GetBlockData ());
delete aborrar;
break;
}
uint BTree::GetNextBlockData ()
{
- /* TODO : Implementar recuperacion */
- return header.block_data_counter++;
+ uint n;
+ if (deleted_block_data.size ()) {
+ std::list<uint>::iterator it = deleted_block_data.begin ();
+ n = *it;
+ deleted_block_data.erase (it);
+ } else {
+ n = header.block_data_counter++;
+ }
+
+ return n;
}
virtual ~Clave () {}
void SetBlockData (int i) { block_data = i; }
+ uint GetBlockData () { return block_data; }
/** Retorna el tamaño en bytes que ocupa la clave */
virtual uint Size () const = 0;