- combo_entry->set_text(name);
- if (CItem::logic_connect) {
- tmp_line.logic = workplace->get_logic_item(CItem::quien);
- tmp_line.store = this;
- workplace->lista_lineas.push_back(tmp_line);
- workplace->on_expose_event(&e);
+ WorkPlace::pointed = ID;
+ list_pointed->push_back(name);
+ combo_entry->set_popdown_strings(*list_pointed);
+ combo_entry->get_entry()->set_text (name);
+ if (CItem::logic_connect && CItem::gate_id != -1) {
+ if ( detect_click_position((int)event->x, (int)event->y) == IN && !workplace->get_logic_item(CItem::gate_id)->get_out_logic_connect()){
+ tmp_line.logic_id = workplace->get_logic_item(CItem::gate_id)->get_id();
+ workplace->get_logic_item(CItem::gate_id)->set_out_connected(true);
+ tmp_line.store_id = ID;
+ workplace->lista_lineas_out.push_back(tmp_line);
+ workplace->queue_draw();
+ } else if (detect_click_position((int)event->x, (int)event->y) == OUT ) {
+ if (dynamic_cast<Not *>(workplace->get_logic_item(CItem::gate_id))) {
+ if ( !dynamic_cast<Not *>(workplace->get_logic_item(CItem::gate_id))->get_in_logic_connect()) {
+ workplace->get_logic_item(CItem::gate_id)->set_in_connected(true);
+ tmp_line.logic_id = CItem::gate_id;
+ tmp_line.store_id = ID;
+ workplace->lista_lineas_out.push_back(tmp_line);
+ workplace->queue_draw();
+ }
+ } else {
+ tmp_line.logic_id = CItem::gate_id;
+ tmp_line.store_id = ID;
+ workplace->lista_lineas_out.push_back(tmp_line);
+ workplace->queue_draw();
+ }
+ }
+ CItem::gate_id = -1;