mirror of
https://github.com/boostorg/asio.git
synced 2026-01-23 17:32:07 +00:00
* Added support for signal handling, using a new class called signal_set. Programs may add one or more signals to the set, and then perform an async_wait() operation. The specified handler will be called when one of the signals occurs. The same signal number may registered with multiple signal_set objects, however the signal number must be used only with Asio. * Added handler tracking, a new debugging aid. When enabled by defining BOOST_ASIO_ENABLE_HANDLER_TRACKING, Asio writes debugging output to the standard error stream. The output records asynchronous operations and the relationships between their handlers. It may be post-processed using the included [^handlerviz.pl] tool to create a visual representation of the handlers (requires GraphViz). * Fixed a bug in asio::streambuf where the consume() function did not always update the internal buffer pointers correctly. The problem may occur when the asio::streambuf is filled with data using the standard C++ member functions such as sputn(). (Note: the problem does not manifest when the streambuf is populated by the Asio free functions read(), async_read(), read_until() or async_read_until().) * Fixed a bug on kqueue-based platforms, where reactor read operations that return false from their perform() function are not correctly re-registered with kqueue. * Modified the buffers_iterator<> and ip::basic_resolver_iterator classes so that the value_type typedefs are non-const byte types. [SVN r69198]
59 lines
1.4 KiB
C++
59 lines
1.4 KiB
C++
//
|
|
// main.cpp
|
|
// ~~~~~~~~
|
|
//
|
|
// Copyright (c) 2003-2011 Christopher M. Kohlhoff (chris at kohlhoff dot com)
|
|
//
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
//
|
|
|
|
#include <iostream>
|
|
#include <boost/asio.hpp>
|
|
#include <boost/bind.hpp>
|
|
#include <signal.h>
|
|
#include "server.hpp"
|
|
#include "file_handler.hpp"
|
|
|
|
int main(int argc, char* argv[])
|
|
{
|
|
try
|
|
{
|
|
// Check command line arguments.
|
|
if (argc != 4)
|
|
{
|
|
std::cerr << "Usage: http_server <address> <port> <doc_root>\n";
|
|
std::cerr << " For IPv4, try:\n";
|
|
std::cerr << " receiver 0.0.0.0 80 .\n";
|
|
std::cerr << " For IPv6, try:\n";
|
|
std::cerr << " receiver 0::0 80 .\n";
|
|
return 1;
|
|
}
|
|
|
|
boost::asio::io_service io_service;
|
|
|
|
// Launch the initial server coroutine.
|
|
http::server4::server(io_service, argv[1], argv[2],
|
|
http::server4::file_handler(argv[3]))();
|
|
|
|
// Wait for signals indicating time to shut down.
|
|
boost::asio::signal_set signals(io_service);
|
|
signals.add(SIGINT);
|
|
signals.add(SIGTERM);
|
|
#if defined(SIGQUIT)
|
|
signals.add(SIGQUIT);
|
|
#endif // defined(SIGQUIT)
|
|
signals.async_wait(boost::bind(
|
|
&boost::asio::io_service::stop, &io_service));
|
|
|
|
// Run the server.
|
|
io_service.run();
|
|
}
|
|
catch (std::exception& e)
|
|
{
|
|
std::cerr << "exception: " << e.what() << "\n";
|
|
}
|
|
|
|
return 0;
|
|
}
|