Boost logo

Boost :

From: Christopher Kohlhoff (chris_at_[hidden])
Date: 2005-11-18 07:06:03


Hello all,

I have just released asio 0.3.5. You can download it, or view the
documentation online, at http://asio.sourceforge.net.

The download page includes packages named boost-asio-proposal-*, which
contain a version of asio converted into boost format. You can copy the
contents of one of these into a boost_1_33_0 distribution and build it
there, but it should also support building in its own directory,
provided you set a BOOST_ROOT environment variable. The Jamfiles are a
little rough, but they should work in theory.

The size of the release is actually less than 0.3.4, which I think is a
good sign :)

In detail, the changes since asio 0.3.4 include:

- Consolidated the free functions read(), read_n() and
  read_at_least_n() into a function named read(); write(),
  write_n() and write_at_least_n() into just write(); and
  likewise for their asynchronous counterparts. The default
  behaviour of read() and write() is now to attempt to transfer
  all of the data (i.e. equivalent to old read_n() and
  write_n()). The _at_least_n() behaviour can be obtained by
  passing a Completion_Condition function object:
    asio::read(s, bufs, asio::transfer_at_least(32));

- Renamed the Stream concept's read(), async_read(), write() and
  async_write() functions to read_some(), async_read_some(),
  write_some() and async_write_some() respectively. This was
  done to make it obvious to a library user that the operation
  can result in a short read or write. The name write() in
  particular was found to be error prone, since most of the time
  it will successfully transfer all of the data. Only occasional
  calls would result in a short write, leading to hard to find
  bugs.

- Graceful connection closure now causes a read to complete with
  an error code (asio::error::eof) rather than returning 0. This
  removes the need for separate total_bytes_transferred and
  last_bytes_transferred handler parameters. It allows a
  function, such as asio::read() and asio::write(), to return an
  error to indicate that it is unable to fulfil its contract due
  to EOF.

- Removed the asio::buffers() function and the ability to
  automatically chain buffer objects together. Instead, the
  asio::buffer() function now returns a type that meets the
  Const_Buffers or Mutable_Buffers concepts as appropriate.
  Scatter-gather I/O should now be performed by explicitly
  placing const_buffer or mutable_buffer objects into a
  container (such as std::vector, std::list or boost::array). To
  read into a single buffer you would now write:
    sock.read(asio::buffer(data, length));
  To send multiple buffers you would use something like:
    std::vector<asio::const_buffer> bufs;
    bufs.push_back(asio::buffer(data1, length1));
    bufs.push_back(asio::buffer(data2, length2));
    sock.write(bufs);

- Added comparison operators to the asio::ipv4::tcp::endpoint
  and asio::ipv4::udp::endpoint classes.

- Removed the error handling expression templates. This
  functionality is better covered by a library such as
  Boost.Lambda.

- Removed the fixed_buffer class from the library's public
  interface. The underlying buffer storage is no longer a
  template parameter on the buffered*_stream classes.

- Removed the wrapped_handler class from the library's public
  interface.

- Removed the consuming_buffers class from the libary's public
  interface.

- Added new certificates for the SSL example, as the original
  ones expired after one month.

- Used implementation-defined types rather than void* in the
  Socket_Option and IO_Control_Command concepts to avoid losing
  type safety.

- Various code cleanup and bug fixes.

- Added support for MSVC 8.0.

- Documentation improvements.

Cheers,
Chris


Boost list run by bdawes at acm.org, gregod at cs.rpi.edu, cpdaniel at pacbell.net, john at johnmaddock.co.uk