]> git.llucax.com Git - z.facultad/75.52/treemulator.git/blobdiff - src/btree.h
Funcion de debug para ver el contenido de un nodo
[z.facultad/75.52/treemulator.git] / src / btree.h
index 540ac38a931644da178aa849bd7fc5f48734a690..06a6941bfdca6806348a53c4ff32f1dfde45d3e0 100644 (file)
 
 #include <iostream>
 #include <string>
 
 #include <iostream>
 #include <string>
+#include <list>
 #include "common.h"
 #include "clave.h"
 #include "common.h"
 #include "clave.h"
+#include "clave_fija.h"
+#include "btree_data.h"
 
 /* alias para codear menos :) */
 
 
 /* alias para codear menos :) */
 
@@ -83,21 +86,26 @@ struct BTreeNodeHeader {
  */
 class BTree {
        public:
  */
 class BTree {
        public:
-               BTree (const char *filename, unsigned int block_size, bool create_new_file = false);
+               BTree (const std::string &filename, unsigned int block_size, bool create_new_file = false);
                ~BTree ();
 
                ~BTree ();
 
-               void AddKey (Clave &k);
-               void DelKey (Clave &k);
+               void AddKey (const Clave &k);
+               void DelKey (const Clave &k);
 
        private:
 
        private:
-               void write_tree_header ();
-               void write_block (uchar *block, uint num);
+               Clave* AddKeyR (const Clave *k, uint node_num);
 
 
+               void WriteFileHeader ();
+
+               void WriteBlock (uchar *block, uint num);
                uchar *ReadBlock (uint num);
 
                void ReadNodoHeader (uchar *node, BTreeNodeHeader *header);
                void WriteNodoHeader (uchar *node, BTreeNodeHeader *header);
 
                uchar *ReadBlock (uint num);
 
                void ReadNodoHeader (uchar *node, BTreeNodeHeader *header);
                void WriteNodoHeader (uchar *node, BTreeNodeHeader *header);
 
+               std::list<BTreeData> ReadKeys (uchar *node, BTreeNodeHeader &node_header);
+               void WriteKeys (uchar *node, BTreeNodeHeader &node_header, std::list<BTreeData> &keys);
+
                std::string filename;
                BTreeFileHeader header;
 
                std::string filename;
                BTreeFileHeader header;
 
@@ -106,6 +114,10 @@ class BTree {
                 *  \TODO Ver si vale la pena
                 */
                FILE *fp;
                 *  \TODO Ver si vale la pena
                 */
                FILE *fp;
+
+
+               /* DEBUG */
+               void PrintNode (uint num);
 };
 
 #endif // _B_TREE_H
 };
 
 #endif // _B_TREE_H