include/boost/corosio/io/io_write_stream.hpp

95.2% Lines (20/21) 100.0% List of functions (29/29) 46.7% Branches (14/30)
io_write_stream.hpp
f(x) Functions (29)
Function Calls Lines Branches Blocks
boost::corosio::io_write_stream::~io_write_stream() :43 16305x 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>&&) :48 1625222x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::const_buffer>::~write_some_awaitable() :48 3250446x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::consuming_buffers<boost::capy::const_buffer>>::write_some_awaitable(boost::corosio::io_write_stream::write_some_awaitable<boost::capy::consuming_buffers<boost::capy::const_buffer>>&&) :48 20x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::consuming_buffers<boost::capy::const_buffer>>::~write_some_awaitable() :48 40x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::consuming_buffers<boost::capy::mutable_buffer>>::write_some_awaitable(boost::corosio::io_write_stream::write_some_awaitable<boost::capy::consuming_buffers<boost::capy::mutable_buffer>>&&) :48 4x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::consuming_buffers<boost::capy::mutable_buffer>>::~write_some_awaitable() :48 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() :48 234284x 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) :56 1625224x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::consuming_buffers<boost::capy::const_buffer>>::write_some_awaitable(boost::corosio::io_write_stream&, boost::capy::consuming_buffers<boost::capy::const_buffer>) :56 20x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::consuming_buffers<boost::capy::mutable_buffer>>::write_some_awaitable(boost::corosio::io_write_stream&, boost::capy::consuming_buffers<boost::capy::mutable_buffer>) :56 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>) :56 234284x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::const_buffer>::await_ready() const :63 812612x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::consuming_buffers<boost::capy::const_buffer>>::await_ready() const :63 10x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::consuming_buffers<boost::capy::mutable_buffer>>::await_ready() const :63 2x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<std::__1::span<boost::capy::const_buffer const, 18446744073709551615ul>>::await_ready() const :63 117142x 100.0% 100.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::const_buffer>::await_resume() const :68 812612x 80.0% 33.3% 57.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::consuming_buffers<boost::capy::const_buffer>>::await_resume() const :68 10x 100.0% 57.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::consuming_buffers<boost::capy::mutable_buffer>>::await_resume() const :68 2x 80.0% 22.2% 57.0% boost::corosio::io_write_stream::write_some_awaitable<std::__1::span<boost::capy::const_buffer const, 18446744073709551615ul>>::await_resume() const :68 117142x 100.0% 66.7% 85.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::const_buffer>::await_suspend(std::__1::coroutine_handle<void>, boost::capy::io_env const*) :75 812612x 80.0% 50.0% 50.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::consuming_buffers<boost::capy::const_buffer>>::await_suspend(std::__1::coroutine_handle<void>, boost::capy::io_env const*) :75 10x 100.0% 50.0% boost::corosio::io_write_stream::write_some_awaitable<boost::capy::consuming_buffers<boost::capy::mutable_buffer>>::await_suspend(std::__1::coroutine_handle<void>, boost::capy::io_env const*) :75 2x 80.0% 33.3% 50.0% boost::corosio::io_write_stream::write_some_awaitable<std::__1::span<boost::capy::const_buffer const, 18446744073709551615ul>>::await_suspend(std::__1::coroutine_handle<void>, boost::capy::io_env const*) :75 117142x 80.0% 50.0% 50.0% boost::corosio::io_write_stream::io_write_stream() :103 16305x 100.0% 100.0% auto boost::corosio::io_write_stream::write_some<boost::capy::const_buffer>(boost::capy::const_buffer const&) :131 812612x 100.0% 100.0% auto boost::corosio::io_write_stream::write_some<boost::capy::consuming_buffers<boost::capy::const_buffer>>(boost::capy::consuming_buffers<boost::capy::const_buffer> const&) :131 10x 100.0% 100.0% auto boost::corosio::io_write_stream::write_some<boost::capy::consuming_buffers<boost::capy::mutable_buffer>>(boost::capy::consuming_buffers<boost::capy::mutable_buffer> const&) :131 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&) :131 117142x 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/io/io_object.hpp>
15 #include <boost/corosio/detail/buffer_param.hpp>
16 #include <boost/capy/io_result.hpp>
17 #include <boost/capy/ex/executor_ref.hpp>
18 #include <boost/capy/ex/io_env.hpp>
19
20 #include <coroutine>
21 #include <cstddef>
22 #include <stop_token>
23 #include <system_error>
24
25 namespace boost::corosio {
26
27 /** Abstract base for streams that support async writes.
28
29 Provides the `write_some` operation via a pure virtual
30 `do_write_some` dispatch point. Concrete classes override
31 `do_write_some` to route through their implementation.
32
33 Uses virtual inheritance from @ref io_object so that
34 @ref io_stream can combine this with @ref io_read_stream
35 without duplicating the `io_object` base.
36
37 @par Thread Safety
38 Distinct objects: Safe.
39 Shared objects: Unsafe.
40
41 @see io_read_stream, io_stream, io_object
42 */
43 class BOOST_COROSIO_DECL io_write_stream : virtual public io_object
44 {
45 protected:
46 /// Awaitable for async write operations.
47 template<class ConstBufferSequence>
48 struct write_some_awaitable
49 {
50 io_write_stream& ios_;
51 ConstBufferSequence buffers_;
52 std::stop_token token_;
53 mutable std::error_code ec_;
54 929766x mutable std::size_t bytes_transferred_ = 0;
55
56 2789298x write_some_awaitable(
57 io_write_stream& ios, ConstBufferSequence buffers) noexcept
58 929766x : ios_(ios)
59 929766x , buffers_(std::move(buffers))
60 929766x {
61 1859532x }
62
63 929766x bool await_ready() const noexcept
64 {
65 929766x return token_.stop_requested();
66 }
67
68 929766x capy::io_result<std::size_t> await_resume() const noexcept
69 {
70
4/6
✓ Branch 0 taken 1 time.
✓ Branch 1 taken 929753 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 10 times.
✗ Branch 4 not taken.
✓ Branch 5 taken 2 times.
929766x if (token_.stop_requested())
71
1/6
✓ Branch 0 taken 1 time.
✗ Branch 1 not taken.
✗ Branch 2 not taken.
✗ Branch 3 not taken.
✗ Branch 4 not taken.
✗ Branch 5 not taken.
1x return {make_error_code(std::errc::operation_canceled), 0};
72
3/6
✓ Branch 0 taken 929753 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 10 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2 times.
✗ Branch 5 not taken.
929765x return {ec_, bytes_transferred_};
73 929766x }
74
75 929766x auto await_suspend(std::coroutine_handle<> h, capy::io_env const* env)
76 -> std::coroutine_handle<>
77 {
78 929766x token_ = env->stop_token;
79
6/12
✓ Branch 0 taken 929754 times.
✗ Branch 1 not taken.
✓ Branch 2 taken 929754 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 10 times.
✗ Branch 5 not taken.
✓ Branch 6 taken 10 times.
✗ Branch 7 not taken.
✓ Branch 8 taken 2 times.
✗ Branch 9 not taken.
✓ Branch 10 taken 2 times.
✗ Branch 11 not taken.
1859532x return ios_.do_write_some(
80 929766x h, env->executor, buffers_, token_, &ec_, &bytes_transferred_);
81 }
82 };
83
84 /** Dispatch a write through the concrete implementation.
85
86 @param h Coroutine handle to resume on completion.
87 @param ex Executor for dispatching the completion.
88 @param buffers Source buffer sequence.
89 @param token Stop token for cancellation.
90 @param ec Output error code.
91 @param bytes Output bytes transferred.
92
93 @return Coroutine handle to resume immediately.
94 */
95 virtual std::coroutine_handle<> do_write_some(
96 std::coroutine_handle<>,
97 capy::executor_ref,
98 buffer_param,
99 std::stop_token,
100 std::error_code*,
101 std::size_t*) = 0;
102
103 16305x io_write_stream() noexcept = default;
104
105 /// Construct from a handle.
106 explicit io_write_stream(handle h) noexcept : io_object(std::move(h)) {}
107
108 io_write_stream(io_write_stream&&) noexcept = default;
109 io_write_stream& operator=(io_write_stream&&) noexcept = delete;
110 io_write_stream(io_write_stream const&) = delete;
111 io_write_stream& operator=(io_write_stream const&) = delete;
112
113 public:
114 /** Asynchronously write data to the stream.
115
116 Suspends the calling coroutine and initiates a kernel-level
117 write. The coroutine resumes when at least one byte is written,
118 an error occurs, or the operation is cancelled.
119
120 This stream must outlive the returned awaitable. The memory
121 referenced by @p buffers must remain valid until the operation
122 completes.
123
124 @param buffers The buffer sequence containing data to write.
125
126 @return An awaitable yielding `(error_code, std::size_t)`.
127
128 @see io_stream::read_some
129 */
130 template<capy::ConstBufferSequence CB>
131 929766x auto write_some(CB const& buffers)
132 {
133 929766x return write_some_awaitable<CB>(*this, buffers);
134 }
135 };
136
137 } // namespace boost::corosio
138
139 #endif
140