X-Git-Url: https://git.llucax.com/z.facultad/75.42/plaqui.git/blobdiff_plain/6e0194f46ac77c18bfeabf84ef94a32f23e41073..6f70c17ffefd6150b68ac0f64a8116e730437408:/Server/src/connection.cpp diff --git a/Server/src/connection.cpp b/Server/src/connection.cpp index 44d74df..c355c86 100644 --- a/Server/src/connection.cpp +++ b/Server/src/connection.cpp @@ -27,23 +27,79 @@ #include "plaqui/server/connection.h" #include +#ifdef DEBUG +# include +#endif // DEBUG + +using namespace std; -using namespace Plaqui; +namespace PlaQui { + +namespace Server { + +Connection::~Connection(void) { +#ifdef DEBUG + cerr << __FILE__ << "(" << __LINE__ << ")" + << ": destructor." << endl; +#endif // DEBUG +} Connection::Connection(const sockbuf::sockdesc& sd): socket(sd) { #ifdef DEBUG - std::cerr << __FILE__ << ": sd = " << sd.sock << std::endl; + cerr << __FILE__ << "(" << __LINE__ << ")" + << ": sd = " << sd.sock; +#endif // DEBUG + host = socket->peerhost(); + port = socket->peerport(); +#ifdef DEBUG + cerr << " | host = " << host << " | port = " << port << endl; +#endif // DEBUG +} + +Connection::Connection(const sockbuf::type& type, const std::string& host, + const Port& port): socket(type), host(host), port(port) { +#ifdef DEBUG + cerr << __FILE__ << "(" << __LINE__ << ")" + << ": type = " << type << " | host = " << host + << " | port = " << port << endl; +#endif // DEBUG +} + +Connection::Connection(const std::string& host, const Port& port): + host(host), port(port) { +#ifdef DEBUG + cerr << __FILE__ << "(" << __LINE__ << ")" + << ": host = " << host << " | port = " << port << endl; #endif // DEBUG } -/* -Connection::Connection(const sockinetbuf& sb): - socket(sb) { +void Connection::finish(void) { +#ifdef DEBUG + cerr << __FILE__ << "(" << __LINE__ << ")" + << ": finish();" << endl; +#endif // DEBUG + //socket_mutex.lock(); + try { + socket->shutdown(sockbuf::shut_readwrite); + // FIXME socket->close(sockbuf::shut_readwrite); + // close(socket->sd()); + } catch (const sockerr& e) { + signal_error().emit(e.serrno(), e.errstr()); + } + //socket_mutex.unlock(); + Runnable::finish(); +} + +const string& Connection::get_host(void) const { + return host; } -*/ -Connection::Connection(sockbuf::type type): - socket(type) { +const Connection::Port& Connection::get_port(void) const { + return port; } +} // namespace Server + +} // namespace PlaQui +