X-Git-Url: https://git.llucax.com/z.facultad/75.52/treemulator.git/blobdiff_plain/0fd0b8da8e1e9c889282ad4cb41f4b4cf2e63838..16ec4547406edcae627dd3ec4bdc448ef605b11a:/viewer/main.cpp?ds=sidebyside diff --git a/viewer/main.cpp b/viewer/main.cpp index f73897b..f7e4d5d 100644 --- a/viewer/main.cpp +++ b/viewer/main.cpp @@ -44,7 +44,6 @@ void zoom_in (); void zoom_normal (); Glib::RefPtr tree; -ViewDebug *vdebug; Gnome::Canvas::Canvas *real_canvas; ViewProperties *real_frame; @@ -55,24 +54,22 @@ int main(int argc, char *argv[]) Gnome::Canvas::init (); Gtk::Window window; - Gtk::HBox hbox; + Gtk::VBox hbox; Gtk::VBox vbox; Gtk::ScrolledWindow area; Gnome::Canvas::Canvas canvas; ViewProperties frame; - ViewDebug debug; real_canvas = &canvas; real_frame = &frame; - vdebug = &debug; canvas.set_scroll_region (0, 0, 100, 100); area.add (canvas); - hbox.pack_start (frame, false, false, 10); hbox.pack_start (area); - hbox.pack_end (debug, false, true, 10); + hbox.pack_start (frame, false, false, 10); + frame.set_size_request (200, 200); Glib::RefPtr actiongroup = Gtk::ActionGroup::create(); @@ -123,7 +120,6 @@ void nuevo_arbol () int type = d.getKeyType (); tree = Glib::RefPtr(new ViewBTree (real_canvas->root(), "test.idx", d.getBlockSize (), type)); tree->signal_selected ().connect ( sigc::mem_fun (*real_frame, &ViewProperties::ShowItem) ); - vdebug->SetTree (tree); if (type == BTree::KEY_FIXED) { std::list lst; std::list::iterator it; @@ -138,9 +134,12 @@ void nuevo_arbol () double l = Random::Double (0.0f, 1.0f); std::cout << l << " >= " << paltas << std::endl; if (l >= paltas) { - tree->AddKey (c); + try { + tree->AddKey (c); + } catch (Exception *e) { + std::cout << "====== " << (std::string)c << e->Message () << std::endl; + } i++; - vdebug->AddKey (c); } else { /* Tengo que borrar una clave entre 0 e "i" de la lista * porque son las que ya agregue. */ @@ -170,14 +169,18 @@ void nuevo_arbol () while (it != lst.end ()) { ClaveVariable c(*it); - tree->AddKey (c); - vdebug->AddKey (c); + try { + tree->AddKey (c); + } catch (Exception *e) { + std::cout << "====== " << (std::string)c << e->Message () << std::endl; + } it++; } } tree->AddNode (0); double x1, x2, y1, y2; tree->get_bounds (x1, y1, x2, y2); + real_canvas->scroll_to (0, 0); } } @@ -206,6 +209,7 @@ void agregar_clave () } delete tree->last_selected; tree->AddNode (0); + real_canvas->scroll_to (0, 0); } } @@ -234,6 +238,7 @@ void borrar_clave () } delete tree->last_selected; tree->AddNode (0); + real_canvas->scroll_to (0, 0); } } @@ -270,6 +275,8 @@ void buscar_clave () tree->AddNode(result->node); tree->HighliteKey (*c); delete result; + delete c; + real_canvas->scroll_to (0, 0); return; // Encontramos, salimos } if (c) delete c;