" <menubar name='MenuBar'>"
" <menu action='MenuFile'>"
" <menuitem action='Nuevo'/>"
+" <menuitem action='Abrir'/>"
" <separator/>"
" <menuitem action='Salir'/>"
" </menu>"
+" <menu action='MenuNode'>"
+" <menuitem action='Ir al Padre'/>"
+" </menu>"
" <menu action='MenuKey'>"
" <menuitem action='Agregar Clave'/>"
" <menuitem action='Borrar Clave'/>"
"</ui>";
void nuevo_arbol ();
+void abrir_arbol ();
void agregar_clave ();
void borrar_clave ();
+void ir_al_padre ();
void buscar_clave ();
void zoom_out ();
void zoom_in ();
actiongroup->add( Gtk::Action::create("MenuFile", "_Arbol") );
actiongroup->add( Gtk::Action::create("Nuevo", Gtk::Stock::NEW), &nuevo_arbol);
+ actiongroup->add( Gtk::Action::create("Abrir", Gtk::Stock::OPEN), &abrir_arbol);
actiongroup->add( Gtk::Action::create("Salir", Gtk::Stock::QUIT), Gtk::AccelKey ("<control>q"), &Gtk::Main::quit);
+ actiongroup->add( Gtk::Action::create("MenuNode", "_Nodo") );
+ actiongroup->add( Gtk::Action::create("Ir al Padre", Gtk::Stock::GO_BACK), Gtk::AccelKey ("<control>b"), &ir_al_padre);
actiongroup->add( Gtk::Action::create("MenuKey", "_Clave") );
actiongroup->add( Gtk::Action::create("Agregar Clave", Gtk::Stock::ADD), Gtk::AccelKey ("<control>a"), &agregar_clave);
actiongroup->add( Gtk::Action::create("Borrar Clave", Gtk::Stock::REMOVE), Gtk::AccelKey ("<control>d"), &borrar_clave);
return 0;
}
+void abrir_arbol ()
+{
+ Gtk::FileChooserDialog dlg ("Abrir Arbol");
+
+ dlg.add_button (Gtk::Stock::CANCEL, Gtk::RESPONSE_CANCEL);
+ dlg.add_button (Gtk::Stock::OPEN, Gtk::RESPONSE_ACCEPT);
+ if (dlg.run () == Gtk::RESPONSE_ACCEPT) {
+ Glib::ustring s = dlg.get_filename ();
+ std::string filename = s;
+ ViewBTree *ptree = ViewBTree::Open (real_canvas->root (), filename);
+ if (ptree != NULL) {
+ tree = Glib::RefPtr<ViewBTree>(ptree);
+ tree->signal_selected ().connect ( sigc::mem_fun (*real_frame, &ViewProperties::ShowItem) );
+ tree->AddNode (0);
+ double x1, x2, y1, y2;
+ tree->get_bounds (x1, y1, x2, y2);
+ real_canvas->set_scroll_region (0, 0, 5000, 5000);
+ real_canvas->scroll_to (0, 0);
+ }
+ }
+}
+
void nuevo_arbol ()
{
real_canvas->set_scroll_region (0, 0, 5000, 5000);
double paltas = bajas / (double)altas;
int type = d.getKeyType ();
- tree = Glib::RefPtr<ViewBTree>(new ViewBTree (real_canvas->root(), "test.idx", d.getBlockSize (), type));
+ int atype = d.getTreeType ();
+ std::string name = d.getName ();
+ tree = Glib::RefPtr<ViewBTree>(new ViewBTree (real_canvas->root(), name+".idx", d.getBlockSize (), atype, type));
+ real_frame->SetTree (tree);
tree->signal_selected ().connect ( sigc::mem_fun (*real_frame, &ViewProperties::ShowItem) );
if (type == BTree::KEY_FIXED) {
std::list<int> lst;
it = lst.begin ();
uint i = 0;
while (it != lst.end ()) {
- ClaveFija c(*it, 0);
+ ClaveFija c(*it);
double l = Random::Double (0.0f, 1.0f);
std::cout << l << " >= " << paltas << std::endl;
otro++;
j++;
}
- ClaveFija c(*otro, 0);
+ ClaveFija c(*otro);
tree->DelKey (c);
std::string sss = c;
it = lst.begin ();
while (it != lst.end ()) {
- ClaveVariable c(*it, 0);
+ ClaveVariable c(*it);
try {
tree->AddKey (c);
if (d.run () == Gtk::RESPONSE_OK)
{
Glib::ustring str_key = d.key();
+ Glib::ustring str_val = d.val();
if (tree->type() == BTree::KEY_FIXED)
{
- ClaveFija c(atoi(str_key.c_str()), 0);
+ ClaveFija c(atoi(str_key.c_str()));
tree->AddKey(c);
}
else
{
- ClaveVariable c(str_key, 0);
+ ClaveVariable c(str_key);
tree->AddKey(c);
}
- delete tree->last_selected;
- tree->AddNode (0);
+
+ /* Muestro la clave agregada */
+ BTreeFindResult* result = 0;
+ Clave *c = NULL;
+ if (tree->type() == BTree::KEY_FIXED) {
+ c = new ClaveFija (atoi(str_key.c_str()));
+ result = tree->FindKey(*c);
+ } else {
+ c = new ClaveVariable (str_key);
+ result = tree->FindKey(*c);
+ }
+ if (result) {
+ tree->Clear ();
+ tree->AddNode(result->node);
+ tree->HighliteKey (*c);
+ delete result;
+ } else {
+ delete tree->last_selected;
+ tree->last_selected = NULL;
+ tree->AddNode (0);
+ }
+ if (c) delete c;
real_canvas->scroll_to (0, 0);
}
}
Glib::ustring str_key = d.key();
if (tree->type() == BTree::KEY_FIXED)
{
- ClaveFija c(atoi(str_key.c_str()), 0);
+ ClaveFija c(atoi(str_key.c_str()));
tree->DelKey(c);
}
else
{
- ClaveVariable c(str_key, 0);
+ ClaveVariable c(str_key);
tree->DelKey(c);
}
delete tree->last_selected;
tree->AddNode (0);
- real_canvas->scroll_to (0, 0);
}
}
+void ir_al_padre ()
+{
+ if (!tree)
+ {
+ Gtk::MessageDialog d("No hay un arbol creado, por favor primero cree un arbol!",
+ false, Gtk::MESSAGE_ERROR, Gtk::BUTTONS_OK, true);
+ d.run();
+ return;
+ }
+ tree->GoBack ();
+}
+
void buscar_clave ()
{
if (!tree)
Glib::ustring str_key = d.key();
if (tree->type() == BTree::KEY_FIXED)
{
- c = new ClaveFija (atoi(str_key.c_str()), 0);
+ c = new ClaveFija (atoi(str_key.c_str()));
result = tree->FindKey(*c);
}
else
{
- c = new ClaveVariable (str_key, 0);
+ c = new ClaveVariable (str_key);
result = tree->FindKey(*c);
}
if (result)