X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fhttp%2Fserver.cpp;h=c52bec4e7e89a2b3a703a657eecc88b102407788;hb=92e8064d9f43ca3e28ce9832cfe475034ab98704;hp=667403e86788c9228e179e1f9677feb1552fb6cc;hpb=bc3d93e11d501f12e25ad05d5eb2dea77f0fa0ec;p=libs%2Fnet.git diff --git a/source/http/server.cpp b/source/http/server.cpp index 667403e..c52bec4 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(list::iterator j=clients.begin(); j!=clients.end(); ++j) - if(j->sock.get()==i->object) + for(const IO::Poller::PolledObject &p: poller.get_result()) + for(auto j=clients.begin(); j!=clients.end(); ++j) + if(j->sock.get()==p.object) { poller.set_object(*j->sock, IO::P_NONE); clients.erase(j); @@ -118,7 +117,7 @@ void Server::data_available() void Server::client_data_available(Client &cl) { - for(list::iterator i=clients.begin(); i!=clients.end(); ++i) + for(auto i=clients.begin(); i!=clients.end(); ++i) if(i->stale && &*i!=&cl) { clients.erase(i);