X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flibr2c2%2Flayout.cpp;h=a6abc500448782341378376a83bf35c6500325ff;hb=9cb5f9ef3c0eaac499ef5d045c513116d6809e56;hp=0025ec3b5b3adcd305ebd08ec8b8a9c44b8622ac;hpb=2220ba2f11705ea9a4e480603d43ab7ed4cf5a89;p=r2c2.git diff --git a/source/libr2c2/layout.cpp b/source/libr2c2/layout.cpp index 0025ec3..a6abc50 100644 --- a/source/libr2c2/layout.cpp +++ b/source/libr2c2/layout.cpp @@ -188,12 +188,21 @@ template T *Layout::pick(const Ray &ray) { const set &objs = objects.get(); + T *closest = 0; + float distance = -1; for(set::const_iterator i=objs.begin(); i!=objs.end(); ++i) if(T *t = dynamic_cast(*i)) - if(t->collide_ray(ray)) - return t; + { + float d = -1; + if(t->collide_ray(ray, &d)) + if(!closest || d(const Ray &); @@ -239,7 +248,7 @@ unsigned Layout::allocate_turnout_address() set used_addrs; const set &tracks = objects.get(); for(set::const_iterator i=tracks.begin(); i!=tracks.end(); ++i) - if((*i)->get_turnout_address()) + if((*i)->get_type().is_turnout()) used_addrs.insert((*i)->get_turnout_address()); unsigned result = next_turnout_addr; @@ -387,12 +396,15 @@ void Layout::tick() i->second->tick(dt); } -void Layout::emergency(const string &msg) +void Layout::emergency(Block *block, const string &msg) { if(driver) driver->halt(true); - IO::print("Emergency: %s\n", msg); - signal_emergency.emit(msg); + if(block) + IO::print("Emergency at %s: %s\n", block->get_name(), msg); + else + IO::print("Emergency: %s\n", msg); + signal_emergency.emit(block, msg); } void Layout::save(const string &fn) const @@ -463,10 +475,16 @@ void Layout::save_dynamic(const string &fn) const IO::BufferedFile out(fn, IO::M_WRITE); DataFile::Writer writer(out); + { + DataFile::Statement st("clock"); + clock.save(st.sub); + writer.write(st); + } + const set &tracks = objects.get(); for(set::const_iterator i=tracks.begin(); i!=tracks.end(); ++i) - if(unsigned taddr = (*i)->get_turnout_address()) - writer.write((DataFile::Statement("turnout"), taddr, (*i)->get_active_path())); + if((*i)->get_type().is_turnout()) + writer.write((DataFile::Statement("turnout"), (*i)->get_turnout_address(), (*i)->get_active_path())); for(map::const_iterator i=trains.begin(); i!=trains.end(); ++i) { @@ -485,7 +503,7 @@ void Layout::sensor_state_changed(Sensor &sensor, Sensor::State state) { Block *block = sensor.get_block(); if(block && !block->get_train()) - emergency(format("Unreserved sensor %d triggered", sensor.get_address())); + emergency(block, "Unreserved sensor triggered"); } } @@ -548,6 +566,7 @@ Layout::Loader::Loader(Layout &l): { add("base", &Layout::base); add("beamgate", &Loader::beamgate); + add("clock", &Loader::clock); add("route", &Loader::route); add("signal", &Loader::signal); add("terrain", &Loader::terrain); @@ -563,6 +582,11 @@ void Layout::Loader::beamgate() load_sub(*gate); } +void Layout::Loader::clock() +{ + load_sub(obj.clock); +} + void Layout::Loader::route() { Route *rte = new Route(obj);