X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/776cd623d2e1078c3fa94492bf1fa29d6f073e75..9a265fbb2d775edde6d17211c9791bcc995c20f7:/Client/src/principal.cpp diff --git a/Client/src/principal.cpp b/Client/src/principal.cpp index 27ebd52..5c53e35 100644 --- a/Client/src/principal.cpp +++ b/Client/src/principal.cpp @@ -13,6 +13,7 @@ #include "item_pump.h" #include "item_union.h" #include "item_drain.h" +#include Principal::Principal(BaseObjectType *co, const Glib::RefPtr &rg):Gtk::Window(co),refXml(rg) { @@ -40,7 +41,6 @@ Principal::Principal(BaseObjectType *co, const Glib::RefPtr & rg->get_widget("ico_conected", ico_conected); dlg_conectar->get_ok_button()->signal_clicked().connect( SigC::slot(*this, &Principal::on_dlg_connect_ok) ); - mnu_prop->signal_activate().connect( SigC::slot(*this, &Principal::on_mnu_prop)); mnu_disconnect->signal_activate().connect( SigC::slot(*this, &Principal::on_mnu_file_disconnect)); conect->signal_activate().connect( SigC::slot(*this, &Principal::on_mnu_file_connect)); bar_connect->signal_clicked().connect( SigC::slot(*this, &Principal::on_mnu_file_connect)); @@ -49,6 +49,7 @@ Principal::Principal(BaseObjectType *co, const Glib::RefPtr & btn_get->signal_clicked().connect( SigC::slot(*this, &Principal::on_get_clicked) ); conexion = NULL; + is_xml_loaded = false; } Principal::~Principal() @@ -75,6 +76,7 @@ void Principal::on_dlg_connect_ok() conexion->signal_error_received().connect( SigC::slot(*this, &Principal::on_conexion_error) ); conexion->signal_connected().connect( SigC::slot(*this, &Principal::on_conexion_connected) ); conexion->signal_finished().connect( SigC::slot(*this, &Principal::on_conexion_finished) ); + conexion->signal_frame_received().connect(SigC::slot(*this, &Principal::on_conexion_frame)); // Lanzo la conexion! try { conexion->run(); @@ -152,6 +154,16 @@ void Principal::on_conexion_connected() { txt_view->get_buffer()->insert_at_cursor("CONNECTED\n"); ico_conected->set( Gtk::Stock::YES , Gtk::IconSize(Gtk::ICON_SIZE_LARGE_TOOLBAR)); + + // Pido la planta por defecto + PlaQui::Server::Command c("plant", "get"); + c.add_arg("default"); + conexion->send(c); +} + +void Principal::on_conexion_frame(const std::string &frame) +{ + std::cout << "LLEGO : " << frame << std::endl; } void Principal::on_conexion_finished() @@ -163,10 +175,15 @@ void Principal::on_conexion_finished() void Principal::on_conexion_ok(const std::string &body) { - std::cout << body << std::endl; - txt_view->get_buffer()->insert_at_cursor("\n"); - txt_view->get_buffer()->insert_at_cursor(Glib::locale_to_utf8(body)); - txt_view->get_buffer()->insert_at_cursor("\n"); + /* lo paso a la carga del XML */ + /* verifico que body este completo */ + if ((body.find("")>0) && (body.find("")>0)) { + loadXML(body); + } else { + txt_view->get_buffer()->insert_at_cursor("\n"); + txt_view->get_buffer()->insert_at_cursor(Glib::locale_to_utf8(body)); + txt_view->get_buffer()->insert_at_cursor("\n"); + } } void Principal::on_conexion_error(unsigned code) @@ -201,15 +218,20 @@ void Principal::on_get_clicked() } -void Principal::on_mnu_prop() +void Principal::loadXML(const std::string &s) { + // ya lo cargue + if (is_xml_loaded) return; + /* Parseo de ejemplo de un XML desde archivo */ xmlDocPtr document; - document = xmlParseFile("test.xml"); + std::cout << s.c_str() << std::endl; + document = xmlParseMemory(s.c_str(),s.size()); if (document == NULL) { + std::cout << "EEERRRRRRROOOOOOOOOO" << std::endl; return; } - + is_xml_loaded = true; /* bien, el archivo se parseo bien! */ xmlNodePtr nodo, items; nodo = document->children; @@ -235,6 +257,7 @@ void Principal::on_mnu_prop() } } + sleep(2); items = items->next; } } @@ -260,7 +283,7 @@ void Principal::loadBomba(xmlNodePtr nodo) } // listo, ya recolecte todos los datos, ahora creo el objeto! - ViewPump *b = Gtk::manage( new ViewPump(name, orientacion) ); + ViewPump *b = new ViewPump(name, orientacion); b->signal_button_press_event().connect(SigC::bind( SigC::slot(*this, &Principal::on_item_clicked), b) ); b->set_position(x,y); work_place->put(*b, x, y); @@ -289,7 +312,7 @@ void Principal::loadCodo(xmlNodePtr nodo) } // listo, ya recolecte todos los datos, ahora creo el objeto! - ViewItem *b = Gtk::manage( new ViewCodo(name, orientacion) ); + ViewItem *b = new ViewCodo(name, orientacion); b->signal_button_press_event().connect(SigC::bind( SigC::slot(*this, &Principal::on_item_clicked), b) ); b->set_position(x,y); work_place->put(*b, x, y); @@ -318,7 +341,7 @@ void Principal::loadConduct(xmlNodePtr nodo) } // listo, ya recolecte todos los datos, ahora creo el objeto! - ViewConduct *b = Gtk::manage( new ViewConduct(name, orientacion) ); + ViewConduct *b = new ViewConduct(name, orientacion); b->signal_button_press_event().connect(SigC::bind( SigC::slot(*this, &Principal::on_item_clicked), b) ); b->set_position(x,y); work_place->put(*b, x, y); @@ -347,7 +370,7 @@ void Principal::loadExclusa(xmlNodePtr nodo) } // listo, ya recolecte todos los datos, ahora creo el objeto! - ViewExclusa *b = Gtk::manage( new ViewExclusa(name, orientacion) ); + ViewExclusa *b = new ViewExclusa(name, orientacion); b->signal_button_press_event().connect(SigC::bind( SigC::slot(*this, &Principal::on_item_clicked), b) ); b->set_position(x,y); work_place->put(*b, x, y); @@ -376,7 +399,7 @@ void Principal::loadTank(xmlNodePtr nodo) } // listo, ya recolecte todos los datos, ahora creo el objeto! - ViewTank *b = Gtk::manage( new ViewTank(name, orientacion) ); + ViewTank *b = new ViewTank(name, orientacion); b->signal_button_press_event().connect(SigC::bind( SigC::slot(*this, &Principal::on_item_clicked), b) ); b->set_position(x,y); work_place->put(*b, x, y); @@ -405,7 +428,7 @@ void Principal::loadUnion(xmlNodePtr nodo) } // listo, ya recolecte todos los datos, ahora creo el objeto! - ViewUnion *b = Gtk::manage( new ViewUnion(name, orientacion) ); + ViewUnion *b = new ViewUnion(name, orientacion); b->signal_button_release_event().connect(SigC::bind( SigC::slot(*this, &Principal::on_item_clicked), b) ); b->set_position(x,y); work_place->put(*b, x, y); @@ -434,7 +457,7 @@ void Principal::loadDrain(xmlNodePtr nodo) } // listo, ya recolecte todos los datos, ahora creo el objeto! - ViewDrain *b = Gtk::manage( new ViewDrain(name, orientacion) ); + ViewDrain *b = new ViewDrain(name, orientacion); b->signal_button_release_event().connect(SigC::bind( SigC::slot(*this, &Principal::on_item_clicked), b) ); b->set_position(x,y); work_place->put(*b, x, y);