X-Git-Url: http://developer.intra2net.com/git/?p=libt2n;a=blobdiff_plain;f=src%2Fcommand_server.cpp;h=4f386ec97b14e9952a17abd9cbf05adb2115139a;hp=e7d6d4da02a839074cd733766961f3474f7e8bdb;hb=45a2ebc9695c4d7be6548b7e0f800d117ae56a0b;hpb=28cb45a5725e9c6054d7048a9bf969b9f2c94d64 diff --git a/src/command_server.cpp b/src/command_server.cpp index e7d6d4d..4f386ec 100644 --- a/src/command_server.cpp +++ b/src/command_server.cpp @@ -34,6 +34,10 @@ #include "container.hxx" #include "log.hxx" +#ifdef HAVE_CONFIG_H +#include +#endif + using namespace std; namespace libt2n @@ -43,12 +47,23 @@ command_server::command_server(server& _s) : s(_s) { // register callback - s.add_callback(new_connection,bind(&command_server::new_connection_callback, boost::ref(*this), _1)); + s.add_callback(new_connection,bind(&command_server::send_hello, boost::ref(*this), _1)); } -void command_server::new_connection_callback(server_connection* conn) +void command_server::send_hello(unsigned int conn_id) { - cerr << "new connection callback: " << conn->get_id() << endl; + server_connection* sc=s.get_connection(conn_id); + + ostringstream hello; + + hello << "T2Nv" << PROTOCOL_VERSION << ';'; + + int byteordercheck=1; + hello.write((char*)&byteordercheck,sizeof(byteordercheck)); + + hello << ';'; + + sc->write(hello.str()); } /// handle a command including deserialization and answering @@ -108,12 +123,12 @@ void command_server::handle_packet(const std::string& packet, server_connection* } /** @brief handle incoming commands - @param usec_timeout wait until new data is found, max timeout usecs. - -1: wait endless, 0: no timeout + @param[in,out] usec_timeout wait until new data is found, max timeout usecs. + -1: wait endless, 0: instant return */ -void command_server::handle(long long usec_timeout) +void command_server::handle(long long usec_timeout, long long* usec_timeout_remaining) { - if (s.fill_buffer(usec_timeout)) + if (s.fill_buffer(usec_timeout,usec_timeout_remaining)) { string packet; unsigned int conn_id;