Have reactor operations return an error code.

This commit is contained in:
chris_kohlhoff 2005-09-21 21:49:37 +00:00
parent 96fcf7a4df
commit 81372532c1
2 changed files with 56 additions and 13 deletions

View File

@ -280,8 +280,14 @@ public:
}
else
{
reactor_.start_write_op(impl, send_handler<Const_Buffers, Handler>(
int result = reactor_.start_write_op(impl,
send_handler<Const_Buffers, Handler>(
impl, demuxer_, buffers, flags, handler));
if (result != 0)
{
asio::error error(result);
demuxer_.post(bind_handler(handler, error, 0));
}
}
}
@ -382,9 +388,14 @@ public:
}
else
{
reactor_.start_write_op(impl,
int result = reactor_.start_write_op(impl,
send_to_handler<Const_Buffers, Endpoint, Handler>(
impl, demuxer_, buffers, flags, destination, handler));
if (result != 0)
{
asio::error error(result);
demuxer_.post(bind_handler(handler, error, 0));
}
}
}
@ -479,18 +490,24 @@ public:
}
else
{
int result;
if (flags & socket_base::message_out_of_band)
{
reactor_.start_except_op(impl,
result = reactor_.start_except_op(impl,
receive_handler<Mutable_Buffers, Handler>(
impl, demuxer_, buffers, flags, handler));
}
else
{
reactor_.start_read_op(impl,
result = reactor_.start_read_op(impl,
receive_handler<Mutable_Buffers, Handler>(
impl, demuxer_, buffers, flags, handler));
}
if (result != 0)
{
asio::error error(result);
demuxer_.post(bind_handler(handler, error, 0));
}
}
}
@ -598,9 +615,14 @@ public:
}
else
{
reactor_.start_read_op(impl,
int result = reactor_.start_read_op(impl,
receive_from_handler<Mutable_Buffers, Endpoint, Handler>(
impl, demuxer_, buffers, flags, sender_endpoint, handler));
if (result != 0)
{
asio::error error(result);
demuxer_.post(bind_handler(handler, error, 0));
}
}
}
@ -705,8 +727,14 @@ public:
}
else
{
reactor_.start_read_op(impl,
accept_handler<Socket, Handler>(impl, demuxer_, peer, handler));
int result = reactor_.start_read_op(impl,
accept_handler<Socket, Handler>(
impl, demuxer_, peer, handler));
if (result != 0)
{
asio::error error(result);
demuxer_.post(bind_handler(handler, error));
}
}
}
@ -770,9 +798,14 @@ public:
}
else
{
reactor_.start_read_op(impl,
int result = reactor_.start_read_op(impl,
accept_endp_handler<Socket, Endpoint, Handler>(
impl, demuxer_, peer, peer_endpoint, handler));
if (result != 0)
{
asio::error error(result);
demuxer_.post(bind_handler(handler, error));
}
}
}
@ -938,8 +971,14 @@ public:
// The connection is happening in the background, and we need to wait
// until the socket becomes writeable.
boost::shared_ptr<bool> completed(new bool(false));
reactor_.start_write_and_except_ops(impl, connect_handler<Handler>(
int result = reactor_.start_write_and_except_ops(
impl, connect_handler<Handler>(
impl, completed, demuxer_, reactor_, handler));
if (result != 0)
{
asio::error error(result);
demuxer_.post(bind_handler(handler, error));
}
}
else
{

View File

@ -80,39 +80,42 @@ public:
// Start a new read operation. The do_operation function of the select_op
// object will be invoked when the given descriptor is ready to be read.
template <typename Handler>
void start_read_op(socket_type descriptor, Handler handler)
int start_read_op(socket_type descriptor, Handler handler)
{
asio::detail::mutex::scoped_lock lock(mutex_);
if (read_op_queue_.enqueue_operation(descriptor, handler))
interrupter_.interrupt();
return 0;
}
// Start a new write operation. The do_operation function of the select_op
// object will be invoked when the given descriptor is ready for writing.
template <typename Handler>
void start_write_op(socket_type descriptor, Handler handler)
int start_write_op(socket_type descriptor, Handler handler)
{
asio::detail::mutex::scoped_lock lock(mutex_);
if (write_op_queue_.enqueue_operation(descriptor, handler))
interrupter_.interrupt();
return 0;
}
// Start a new exception operation. The do_operation function of the select_op
// object will be invoked when the given descriptor has exception information
// available.
template <typename Handler>
void start_except_op(socket_type descriptor, Handler handler)
int start_except_op(socket_type descriptor, Handler handler)
{
asio::detail::mutex::scoped_lock lock(mutex_);
if (except_op_queue_.enqueue_operation(descriptor, handler))
interrupter_.interrupt();
return 0;
}
// Start a new write and exception operations. The do_operation function of
// the select_op object will be invoked when the given descriptor is ready
// for writing or has exception information available.
template <typename Handler>
void start_write_and_except_ops(socket_type descriptor, Handler handler)
int start_write_and_except_ops(socket_type descriptor, Handler handler)
{
asio::detail::mutex::scoped_lock lock(mutex_);
bool interrupt = write_op_queue_.enqueue_operation(descriptor, handler);
@ -120,6 +123,7 @@ public:
|| interrupt;
if (interrupt)
interrupter_.interrupt();
return 0;
}
// Cancel all operations associated with the given descriptor. The