include/boost/corosio/io/io_write_stream.hpp

88.9% Lines (8/9) 100.0% List of functions (21/21) 33.3% Branches (4/12)
io_write_stream.hpp
f(x) Functions (21)
Function Calls Lines Branches Blocks
boost::corosio::io_write_stream::~io_write_stream() :44 11676x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::const_buffer>::write_some_awaitable(boost::corosio::io_write_stream::write_some_awaitable<boost::capy::const_buffer>&&) :49 706508x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::const_buffer>::~write_some_awaitable() :49 1413018x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view>::write_some_awaitable(boost::corosio::io_write_stream::write_some_awaitable<boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view>&&) :49 28x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view>::~write_some_awaitable() :49 56x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view>::write_some_awaitable(boost::corosio::io_write_stream::write_some_awaitable<boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view>&&) :49 4x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view>::~write_some_awaitable() :49 8x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<std::__1::span<boost::capy::const_buffer const, 18446744073709551615ul>>::~write_some_awaitable() :49 177484x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::const_buffer>::write_some_awaitable(boost::corosio::io_write_stream&, boost::capy::const_buffer) :55 706510x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view>::write_some_awaitable(boost::corosio::io_write_stream&, boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view) :55 28x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view>::write_some_awaitable(boost::corosio::io_write_stream&, boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view) :55 4x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<std::__1::span<boost::capy::const_buffer const, 18446744073709551615ul>>::write_some_awaitable(boost::corosio::io_write_stream&, std::__1::span<boost::capy::const_buffer const, 18446744073709551615ul>) :55 177484x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::const_buffer>::dispatch(std::__1::coroutine_handle<void>, boost::capy::executor_ref) const :59 353255x 75.0% 50.0% 50.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view>::dispatch(std::__1::coroutine_handle<void>, boost::capy::executor_ref) const :59 14x 75.0% 50.0% 50.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view>::dispatch(std::__1::coroutine_handle<void>, boost::capy::executor_ref) const :59 2x 75.0% 16.7% 50.0% boost::corosio::io_write_stream::write_some_awaitable<std::__1::span<boost::capy::const_buffer const, 18446744073709551615ul>>::dispatch(std::__1::coroutine_handle<void>, boost::capy::executor_ref) const :59 88742x 75.0% 50.0% 50.0% boost::corosio::io_write_stream::io_write_stream() :86 11676x 100.0% 100.0% auto boost::corosio::io_write_stream::write_some<boost::capy::const_buffer>(boost::capy::const_buffer const&) :114 353255x 100.0% 100.0% auto boost::corosio::io_write_stream::write_some<boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view>(boost::capy::detail::slice_impl<boost::capy::const_buffer>::data_view const&) :114 14x 100.0% 100.0% auto boost::corosio::io_write_stream::write_some<boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view>(boost::capy::detail::slice_impl<boost::capy::mutable_buffer>::data_view const&) :114 2x 100.0% 100.0% auto boost::corosio::io_write_stream::write_some<std::__1::span<boost::capy::const_buffer const, 18446744073709551615ul>>(std::__1::span<boost::capy::const_buffer const, 18446744073709551615ul> const&) :114 88742x 100.0% 100.0%
Line Branch TLA Hits Source Code
1 //
2 // Copyright (c) 2026 Steve Gerbino
3 //
4 // Distributed under the Boost Software License, Version 1.0. (See accompanying
5 // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
6 //
7 // Official repository: https://github.com/cppalliance/corosio
8 //
9
10 #ifndef BOOST_COROSIO_IO_IO_WRITE_STREAM_HPP
11 #define BOOST_COROSIO_IO_IO_WRITE_STREAM_HPP
12
13 #include <boost/corosio/detail/config.hpp>
14 #include <boost/corosio/detail/op_base.hpp>
15 #include <boost/corosio/io/io_object.hpp>
16 #include <boost/corosio/detail/buffer_param.hpp>
17 #include <boost/capy/io_result.hpp>
18 #include <boost/capy/ex/executor_ref.hpp>
19 #include <boost/capy/ex/io_env.hpp>
20
21 #include <coroutine>
22 #include <cstddef>
23 #include <stop_token>
24 #include <system_error>
25
26 namespace boost::corosio {
27
28 /** Abstract base for streams that support async writes.
29
30 Provides the `write_some` operation via a pure virtual
31 `do_write_some` dispatch point. Concrete classes override
32 `do_write_some` to route through their implementation.
33
34 Uses virtual inheritance from @ref io_object so that
35 @ref io_stream can combine this with @ref io_read_stream
36 without duplicating the `io_object` base.
37
38 @par Thread Safety
39 Distinct objects: Safe.
40 Shared objects: Unsafe.
41
42 @see io_read_stream, io_stream, io_object
43 */
44 class BOOST_COROSIO_DECL io_write_stream : virtual public io_object
45 {
46 protected:
47 /// Awaitable for async write operations.
48 template<class ConstBufferSequence>
49 struct write_some_awaitable
50 : detail::bytes_op_base<write_some_awaitable<ConstBufferSequence>>
51 {
52 io_write_stream& ios_;
53 ConstBufferSequence buffers_;
54
55 884026x write_some_awaitable(
56 io_write_stream& ios, ConstBufferSequence buffers) noexcept
57 884026x : ios_(ios), buffers_(std::move(buffers)) {}
58
59 442013x std::coroutine_handle<> dispatch(
60 std::coroutine_handle<> h, capy::executor_ref ex) const
61 {
62
4/12
✓ Branch 0 taken 442011 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 442011 times.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
884026x return ios_.do_write_some(
63 442013x h, ex, buffers_, this->token_, &this->ec_, &this->bytes_);
64 }
65 };
66
67 /** Dispatch a write through the concrete implementation.
68
69 @param h Coroutine handle to resume on completion.
70 @param ex Executor for dispatching the completion.
71 @param buffers Source buffer sequence.
72 @param token Stop token for cancellation.
73 @param ec Output error code.
74 @param bytes Output bytes transferred.
75
76 @return Coroutine handle to resume immediately.
77 */
78 virtual std::coroutine_handle<> do_write_some(
79 std::coroutine_handle<>,
80 capy::executor_ref,
81 buffer_param,
82 std::stop_token,
83 std::error_code*,
84 std::size_t*) = 0;
85
86 11676x io_write_stream() noexcept = default;
87
88 /// Construct from a handle.
89 explicit io_write_stream(handle h) noexcept : io_object(std::move(h)) {}
90
91 io_write_stream(io_write_stream&&) noexcept = default;
92 io_write_stream& operator=(io_write_stream&&) noexcept = delete;
93 io_write_stream(io_write_stream const&) = delete;
94 io_write_stream& operator=(io_write_stream const&) = delete;
95
96 public:
97 /** Asynchronously write data to the stream.
98
99 Suspends the calling coroutine and initiates a kernel-level
100 write. The coroutine resumes when at least one byte is written,
101 an error occurs, or the operation is cancelled.
102
103 This stream must outlive the returned awaitable. The memory
104 referenced by @p buffers must remain valid until the operation
105 completes.
106
107 @param buffers The buffer sequence containing data to write.
108
109 @return An awaitable yielding `(error_code, std::size_t)`.
110
111 @see io_stream::read_some
112 */
113 template<capy::ConstBufferSequence CB>
114 442013x auto write_some(CB const& buffers)
115 {
116 442013x return write_some_awaitable<CB>(*this, buffers);
117 }
118 };
119
120 } // namespace boost::corosio
121
122 #endif
123