summaryrefslogtreecommitdiff
path: root/modules/io/c++/io.cpp
diff options
context:
space:
mode:
authorClaudius 'keldu' Holeksa <mail@keldu.de>2024-10-16 18:51:50 +0200
committerClaudius 'keldu' Holeksa <mail@keldu.de>2024-10-16 18:51:50 +0200
commitb048b02732cbfcfbb95bb8e16dec71aca0e977f4 (patch)
tree8f948159473f40ca42c73d75e61d8d03c3b38f24 /modules/io/c++/io.cpp
parentb10d0b0e1a30eb02777f5a02b81bf45e09749edb (diff)
Reworked abstraction for network
Diffstat (limited to 'modules/io/c++/io.cpp')
-rw-r--r--modules/io/c++/io.cpp53
1 files changed, 0 insertions, 53 deletions
diff --git a/modules/io/c++/io.cpp b/modules/io/c++/io.cpp
index 06c9cbb..50423e1 100644
--- a/modules/io/c++/io.cpp
+++ b/modules/io/c++/io.cpp
@@ -4,59 +4,6 @@
namespace saw {
-async_io_stream::async_io_stream(own<io_stream> str)
- : stream_{std::move(str)},
- read_ready_{stream_->read_ready()
- .then([this]() { read_stepper_.read_step(*stream_); })
- .sink()},
- write_ready_{stream_->write_ready()
- .then([this]() { write_stepper_.write_step(*stream_); })
- .sink()},
- read_disconnected_{stream_->on_read_disconnected()
- .then([this]() {
- if (read_stepper_.on_read_disconnect) {
- read_stepper_.on_read_disconnect->feed();
- }
- })
- .sink()} {}
-
-void async_io_stream::read(void *buffer, size_t min_length, size_t max_length) {
- SAW_ASSERT(buffer && max_length >= min_length && min_length > 0) { return; }
-
- SAW_ASSERT(!read_stepper_.read_task.has_value()) { return; }
-
- read_stepper_.read_task = read_task_and_step_helper::read_io_task{
- buffer, min_length, max_length, 0};
- read_stepper_.read_step(*stream_);
-}
-
-conveyor<size_t> async_io_stream::read_done() {
- auto caf = new_conveyor_and_feeder<size_t>();
- read_stepper_.read_done = std::move(caf.feeder);
- return std::move(caf.conveyor);
-}
-
-conveyor<void> async_io_stream::on_read_disconnected() {
- auto caf = new_conveyor_and_feeder<void>();
- read_stepper_.on_read_disconnect = std::move(caf.feeder);
- return std::move(caf.conveyor);
-}
-
-void async_io_stream::write(const void *buffer, size_t length) {
- SAW_ASSERT(buffer && length > 0) { return; }
-
- SAW_ASSERT(!write_stepper_.write_task.has_value()) { return; }
-
- write_stepper_.write_task =
- write_task_and_step_helper::write_io_task{buffer, length, 0};
- write_stepper_.write_step(*stream_);
-}
-
-conveyor<size_t> async_io_stream::write_done() {
- auto caf = new_conveyor_and_feeder<size_t>();
- write_stepper_.write_done = std::move(caf.feeder);
- return std::move(caf.conveyor);
-}
string_network_address::string_network_address(const std::string &address,
uint16_t port)