X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FSocketHandle.cc;fp=Socket%2FSocketHandle.cc;h=3878a362c77c57d833ad09716d45ce5022a9113e;hb=171b7d9c23896219fc63a6c4a75fc86dfd4bb042;hp=d2ad81c4b5c2182157bfd5820bbc33c569adc96d;hpb=edaa268609b73b4f48b28c5a7a577b6ffd4cec3b;p=senf.git diff --git a/Socket/SocketHandle.cc b/Socket/SocketHandle.cc index d2ad81c..3878a36 100644 --- a/Socket/SocketHandle.cc +++ b/Socket/SocketHandle.cc @@ -38,24 +38,12 @@ prefix_ void senf::SocketBody::v_close() { - if (::shutdown(fd(),SHUT_RDWR) < 0) - throw SystemException(errno); - if (::close(fd()) < 0) - throw SystemException(errno); + protocol().close(); } prefix_ void senf::SocketBody::v_terminate() { - struct linger ling; - ling.l_onoff = 0; - ling.l_linger = 0; - - // We purposely IGNORE any errors: this method is used to try and - // terminate the connection ignoring any possible problems - - ::setsockopt(fd(),SOL_SOCKET,SO_LINGER,&ling,sizeof(ling)); - ::shutdown(fd(),SHUT_RDWR); - ::close(fd()); + protocol().terminate(); } prefix_ bool senf::SocketBody::v_eof()