5 // Copyright (c) 2003-2012 Christopher M. Kohlhoff (chris at kohlhoff dot com)
7 // Distributed under the Boost Software License, Version 1.0. (See accompanying
8 // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
11 #include <boost/asio.hpp>
12 #include <boost/bind.hpp>
15 #include "stream_socket_service.hpp"
17 typedef boost::asio::basic_stream_socket<boost::asio::ip::tcp,
18 services::stream_socket_service<boost::asio::ip::tcp> > debug_stream_socket;
20 char read_buffer[1024];
22 void read_handler(const boost::system::error_code& e,
23 std::size_t bytes_transferred, debug_stream_socket* s)
27 std::cout.write(read_buffer, bytes_transferred);
29 s->async_read_some(boost::asio::buffer(read_buffer),
30 boost::bind(read_handler, boost::asio::placeholders::error,
31 boost::asio::placeholders::bytes_transferred, s));
35 void connect_handler(const boost::system::error_code& e, debug_stream_socket* s)
39 s->async_read_some(boost::asio::buffer(read_buffer),
40 boost::bind(read_handler, boost::asio::placeholders::error,
41 boost::asio::placeholders::bytes_transferred, s));
45 std::cerr << e.message() << std::endl;
49 int main(int argc, char* argv[])
55 std::cerr << "Usage: daytime_client <host>" << std::endl;
59 boost::asio::io_service io_service;
61 // Set the name of the file that all logger instances will use.
62 services::logger logger(io_service, "");
63 logger.use_file("log.txt");
65 // Resolve the address corresponding to the given host.
66 boost::asio::ip::tcp::resolver resolver(io_service);
67 boost::asio::ip::tcp::resolver::query query(argv[1], "daytime");
68 boost::asio::ip::tcp::resolver::iterator iterator = resolver.resolve(query);
70 // Start an asynchronous connect.
71 debug_stream_socket socket(io_service);
72 boost::asio::async_connect(socket, iterator,
73 boost::bind(connect_handler,
74 boost::asio::placeholders::error, &socket));
76 // Run the io_service until all operations have finished.
79 catch (std::exception& e)
81 std::cerr << e.what() << std::endl;