X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fhttp%2Fserver.cpp;fp=source%2Fhttp%2Fserver.cpp;h=6055f008e4ff13328a6bf5409584a7e96f682458;hb=62ea6954a91568c900ad8155999bea264dfa72f3;hp=667403e86788c9228e179e1f9677feb1552fb6cc;hpb=f97f21c17f24e1d426e5b5863676071a5809b185;p=libs%2Fnet.git diff --git a/source/http/server.cpp b/source/http/server.cpp index 667403e..6055f00 100644 --- a/source/http/server.cpp +++ b/source/http/server.cpp @@ -54,15 +54,15 @@ void Server::use_event_dispatcher(IO::EventDispatcher *ed) if(event_disp) { event_disp->remove(sock); - for(list::iterator i=clients.begin(); i!=clients.end(); ++i) - event_disp->remove(*i->sock); + for(Client &c: clients) + event_disp->remove(*c.sock); } event_disp = ed; if(event_disp) { event_disp->add(sock); - for(list::iterator i=clients.begin(); i!=clients.end(); ++i) - event_disp->add(*i->sock); + for(Client &c: clients) + event_disp->add(*c.sock); } } @@ -86,18 +86,17 @@ void Server::cancel_keepalive(Response &resp) void Server::close_connections(const Time::TimeDelta &timeout) { IO::Poller poller; - for(list::iterator i=clients.begin(); i!=clients.end(); ++i) + for(Client &c: clients) { - i->sock->shutdown(IO::M_WRITE); - poller.set_object(*i->sock, IO::P_INPUT); + c.sock->shutdown(IO::M_WRITE); + poller.set_object(*c.sock, IO::P_INPUT); } while(!clients.empty() && poller.poll(timeout)) { - const vector &result = poller.get_result(); - for(vector::const_iterator i=result.begin(); i!=result.end(); ++i) + for(const IO::Poller::PolledObject &p: poller.get_result()) for(list::iterator j=clients.begin(); j!=clients.end(); ++j) - if(j->sock.get()==i->object) + if(j->sock.get()==p.object) { poller.set_object(*j->sock, IO::P_NONE); clients.erase(j);