drp_protocol->set_selected_index(0);
- const Catalogue::VehicleMap &cat_vtypes = engineer.get_layout().get_catalogue().get_vehicles();
- for(Catalogue::VehicleMap::const_iterator i=cat_vtypes.begin(); i!=cat_vtypes.end(); ++i)
- if(i->second->is_locomotive())
- loco_types.append(i->second);
+ const Catalogue::ObjectMap &obj_types = engineer.get_layout().get_catalogue().get_all();
+ for(Catalogue::ObjectMap::const_iterator i=obj_types.begin(); i!=obj_types.end(); ++i)
+ if(const VehicleType *vt = dynamic_cast<const VehicleType *>(i->second))
+ if(vt->is_locomotive())
+ loco_types.append(vt);
+}
+
+void NewTrainDialog::prefill(const Driver::DetectedLocomotive &loco)
+{
+ drp_protocol->set_selected_index(protocols.find(loco.protocol));
+ ent_address->set_text(lexical_cast<string>(loco.address));
+ ent_name->set_text(loco.name);
}
void NewTrainDialog::on_response(int code)