Christopher Kohlhoff 9e03478ba1 Add range-based experimental::make_parallel_group().
Added new overloads of experimental::make_parallel_group that may be used
to launch a dynamically-sized set of asynchronous operations, where all
operations are the same type. For example:

  using op_type = decltype(
      socket1.async_read_some(
        boost::asio::buffer(data1),
        boost::asio::deferred
      )
    );

  std::vector<op_type> ops;

  ops.push_back(
      socket1.async_read_some(
        boost::asio::buffer(data1),
        boost::asio::deferred
      )
    );

  ops.push_back(
      socket2.async_read_some(
        boost::asio::buffer(data2),
        boost::asio::deferred
      )
    );

  boost::asio::experimental::make_parallel_group(ops).async_wait(
      boost::asio::experimental::wait_for_all(),
      [](
          std::vector<std::size_t> completion_order,
          std::vector<boost::system::error_code> e,
          std::vector<std::size_t> n
        )
      {
        for (std::size_t i = 0; i < completion_order.size(); ++i)
        {
          std::size_t idx = completion_order[i];
          std::cout << "socket " << idx << " finished: ";
          std::cout << e[idx] << ", " << n[idx] << "\n";
        }
      }
    );

Thanks go to Klemens Morgenstern for supplying part of this implementation.
2022-11-03 00:48:45 +11:00
..
2022-03-02 21:57:41 +11:00
2022-03-02 21:23:52 +11:00
2022-03-02 21:57:42 +11:00
2022-03-02 21:23:52 +11:00
2022-03-02 21:23:52 +11:00
2022-03-02 21:23:52 +11:00
2022-03-02 21:23:52 +11:00
2022-03-02 21:23:52 +11:00
2022-03-02 21:23:52 +11:00
2022-03-02 21:23:52 +11:00
2022-03-02 21:23:52 +11:00
2022-03-02 21:23:52 +11:00
2022-03-02 21:23:52 +11:00
2022-03-02 21:23:52 +11:00