]> git.llucax.com Git - z.facultad/75.52/treemulator.git/blobdiff - viewer/view_btree.h
Paso el block_data a BTree en lugar de Clave.
[z.facultad/75.52/treemulator.git] / viewer / view_btree.h
index d8e585ad62752e04931e1e909b92f8f4b0b85bf5..18f4df7ec162cda5d4ca5e162e3bf851d27e50b4 100644 (file)
@@ -4,20 +4,26 @@
 
 #include <libgnomecanvasmm.h>
 #include <string>
+#include <stack>
 
 #include "btree.h"
 #include "view_node.h"
 
-#define NODE_WIDTH 500
-#define NODE_HEIGHT 50
-
 using namespace Gnome;
 
+class ViewNode;
+
 class ViewBTree : public Canvas::Group, public BTree {
        public:
-               ViewBTree (Canvas::Group *parent, std::string filename);
+               ViewBTree (Canvas::Group *parent, std::string filename, uint block_size, int tree_type, int type);
+
+               void Clear ();
+               void HighliteKey (Clave &k);
+               void GoBack ();
 
                static double byte_to_pixels;
+               static double node_width;
+               static double node_height;
 
                typedef SigC::Signal2<void, BTreeData *, BTreeNodeHeader&> type_signal_selected;
                type_signal_selected signal_selected ();
@@ -29,10 +35,15 @@ class ViewBTree : public Canvas::Group, public BTree {
                /* Control para no poner 2 veces un nodo */
                /* Un nodo que quiera ser puesto 2 veces es un bug :) */
                std::map<uint,bool> node_placed;
+               std::stack<uint> back;
+               uint last_visited;
 
-               void AddNode (uint num);
-               void on_item_selected (BTreeData *, uint);
+       public:
+               void AddNode (uint num, uint padre = 0);
+               void on_item_selected (BTreeData *, uint, ViewNode *);
+               void on_item_activated (BTreeData *, uint, ViewNode *);
 
+               ViewNode *last_selected;
 };
 
 #endif