X-Git-Url: https://git.llucax.com/z.facultad/75.52/treemulator.git/blobdiff_plain/8f65edaf64b0014de583abe4f6b29d75be1d77ce..2ab8041933e77875de62bc73e76febc528af258e:/src/btree.h diff --git a/src/btree.h b/src/btree.h index 6764a63..a67fa4c 100644 --- a/src/btree.h +++ b/src/btree.h @@ -44,20 +44,24 @@ * tomar una idea simimar) */ -#include -#include -#include +#include +#include +#include +#include "common.h" +#include "clave.h" +#include "clave_fija.h" +#include "clave_variable.h" +#include "btree_data.h" /* alias para codear menos :) */ -typedef unsigned char uchar; /** Encabezado del archivo BTree */ -typedef struct _btree_file_ { - unsigned int block_size; -} BTreeFileHeader; +struct BTreeFileHeader { + uint block_size; +}; /** Encabezado de un bloque */ -typedef struct _btree_header_ { +struct BTreeNodeHeader { /** Indica a que nivel corresponde un bloque * * nivel == 0 : una hoja @@ -73,18 +77,7 @@ typedef struct _btree_header_ { /** Cantidad de elementos en el nodo */ unsigned int item_count; -} BTreeHeader; - -typedef struct _btree_ { - char *filename; - BTreeFileHeader header; - - /** Apunta al archivo de datos, asi se abre solo 1 vez - * - * \TODO Ver si vale la pena - */ - FILE *fp; -} BTree; +}; /** Crea un nuevo arbol B * @@ -92,29 +85,51 @@ typedef struct _btree_ { * \param block_size TamaƱo de bloque a utilizar * \return Un nuevo arbol B creado o NULL en caso de error */ -BTree *btree_create (const char *filename, unsigned int block_size); +class BTree { + public: + BTree (const std::string &filename, unsigned int block_size, int k_t = KEY_FIXED, bool create_new_file = false); + ~BTree (); -/** Abre un arbol B existente - * - * \param filename Nombre del archivo a abrir - * \return El arbol abierto o NULL en caso de error - */ -BTree *btree_open (const char *filename); + /** Tipos de clave a usar */ + enum { + KEY_FIXED, + KEY_VARIABLE + }; -/** Agrega una clave en el arbol - * - * \TODO Definir parametros - */ -int btree_add (BTree *); + void AddKey (const Clave &k); + void DelKey (const Clave &k); + + protected: + Clave* AddKeyR (const Clave *k, uint node_num, uint &left_child, uint &right_child); + Clave* AddKeyOtherR (const Clave *k, uint node_num, uint &left_child, uint &right_child); + Clave* AddKeyLeafR (const Clave *k, uint node_num, uint &left_child, uint &right_child); + + void WriteFileHeader (); + + void WriteBlock (uchar *block, uint num); + uchar *ReadBlock (uint num); + uchar *NewBlock (uint &num); + + void ReadNodoHeader (uchar *node, BTreeNodeHeader *header); + void WriteNodoHeader (uchar *node, BTreeNodeHeader *header); + + std::list ReadKeys (uchar *node, BTreeNodeHeader &node_header); + void WriteKeys (uchar *node, BTreeNodeHeader &node_header, std::list &keys); + + std::string filename; + BTreeFileHeader header; + int key_type; + + /** Apunta al archivo de datos, asi se abre solo 1 vez + * + * \TODO Ver si vale la pena + */ + FILE *fp; -/** Borra una clave del arbol - * - * \TODO Definir parametros - */ -int btree_del (BTree *); -/** Cierra el arbol y libera los recursos */ -int btree_close (BTree *); + /* DEBUG */ + void PrintNode (uint num); +}; #endif // _B_TREE_H