X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fhttp%2Fserver.cpp;h=c52bec4e7e89a2b3a703a657eecc88b102407788;hb=dd1884f1aaef4df246d78cabc9d937e5ebc3e511;hp=97a42b575477a6f89938d1333ac779db2b03842e;hpb=3bea0872d89d4e980d1df6a24298bbb7f8e101fb;p=libs%2Fnet.git diff --git a/source/http/server.cpp b/source/http/server.cpp index 97a42b5..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); } } @@ -83,6 +83,28 @@ void Server::cancel_keepalive(Response &resp) get_client_by_response(resp).keepalive = false; } +void Server::close_connections(const Time::TimeDelta &timeout) +{ + IO::Poller poller; + for(Client &c: clients) + { + c.sock->shutdown(IO::M_WRITE); + poller.set_object(*c.sock, IO::P_INPUT); + } + + while(!clients.empty() && poller.poll(timeout)) + { + 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); + break; + } + } +} + void Server::data_available() { Net::StreamSocket *csock = sock.accept(); @@ -95,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);