X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FSocketProtocol.cc;h=13ee94e7c729ad7b7b67b4a106d29ed63d3adc68;hb=1ad3873b372da6187b1fbc645bf276287d2efb54;hp=fc5fd4c895936622f0f99b03bfb70a406ec9458d;hpb=31d85cd6b8e03c5ecc924ca8892906be1bab702f;p=senf.git diff --git a/Socket/SocketProtocol.cc b/Socket/SocketProtocol.cc index fc5fd4c..13ee94e 100644 --- a/Socket/SocketProtocol.cc +++ b/Socket/SocketProtocol.cc @@ -24,6 +24,7 @@ \brief SocketProtocol and ConcreteSocketProtocol non-inline non-template implementation */ +#include #include "SocketProtocol.hh" //#include "SocketProtocol.ih" @@ -32,6 +33,29 @@ //#include "SocketProtocol.mpp" #define prefix_ ///////////////////////////////cc.p//////////////////////////////////////// +prefix_ void senf::SocketProtocol::close() + const +{ + if (::shutdown(body().fd(),SHUT_RDWR) < 0) + throwErrno(); + if (::close(body().fd()) < 0) + throwErrno(); +} + +prefix_ void senf::SocketProtocol::terminate() + const +{ + 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(body().fd(),SOL_SOCKET,SO_LINGER,&ling,sizeof(ling)); + ::shutdown(body().fd(),SHUT_RDWR); + ::close(body().fd()); +} prefix_ void senf::SocketProtocol::state(SocketStateMap & map, unsigned lod) const @@ -49,4 +73,5 @@ prefix_ void senf::SocketProtocol::state(SocketStateMap & map, unsigned lod) // indent-tabs-mode: nil // ispell-local-dictionary: "american" // compile-command: "scons -u test" +// comment-column: 40 // End: