From 05a7fa9a2815b63b5b6f7eea107807e33aa62137 Mon Sep 17 00:00:00 2001 From: Claudius 'keldu' Holeksa Date: Tue, 22 Oct 2024 18:33:00 +0200 Subject: Trying to get the reference working --- modules/codec/c++/schema.hpp | 1 + modules/remote/c++/remote_loopback.hpp | 4 ++-- modules/remote/c++/remote_loopback_base.hpp | 21 ++++++++++++++----- modules/remote/tests/remote_loopback.cpp | 32 ++++++++++++++++++++++------- 4 files changed, 44 insertions(+), 14 deletions(-) (limited to 'modules') diff --git a/modules/codec/c++/schema.hpp b/modules/codec/c++/schema.hpp index c2cacd5..c0fb66f 100644 --- a/modules/codec/c++/schema.hpp +++ b/modules/codec/c++/schema.hpp @@ -195,6 +195,7 @@ template struct Interface { template struct Interface,Names>...> { static constexpr string_literal name = "Interface"; + static constexpr uint64_t size = sizeof...(Responses); }; // NOLINTEND diff --git a/modules/remote/c++/remote_loopback.hpp b/modules/remote/c++/remote_loopback.hpp index c651589..0e9eb2d 100644 --- a/modules/remote/c++/remote_loopback.hpp +++ b/modules/remote/c++/remote_loopback.hpp @@ -76,9 +76,9 @@ public: template error_or< id< - typename schema_member_type::type::Response + typename schema_member_type::type::ResponseT > - > call(id::type::Request> id_param){ + > call(id::type::RequestT> id_param){ return make_error(); } diff --git a/modules/remote/c++/remote_loopback_base.hpp b/modules/remote/c++/remote_loopback_base.hpp index 5e5e108..7a567b2 100644 --- a/modules/remote/c++/remote_loopback_base.hpp +++ b/modules/remote/c++/remote_loopback_base.hpp @@ -54,14 +54,19 @@ private: template error_or find_data_servers_ele(typename rpc_server::DataServers& ret_val){ - + if } template error_or::DataServers> find_data_servers(){ typename rpc_server::DataServers ret_val; - + { + auto eov = find_data_servers_ele(ret_val); + if(eov.is_error()){ + return std::move(eov.get_error()); + } + } return ret_val; } @@ -77,15 +82,21 @@ public: * Connect to a remote */ template - conveyor> connect(const remote_address& addr); + conveyor> rpc_connect(const remote_address& addr); /** * Start listening */ template - error_or>> rpc_listen(const remote_address& addr, typename rpc_server::InterfaceT iface){ + error_or>> rpc_listen(remote_address& addr, typename rpc_server::InterfaceT iface){ + + auto eo_dat_srvs = find_data_servers(); + if(eo_dat_srvs.is_error()){ + return std::move(eo_dat_srvs.get_error()); + } + auto& dat_srvs = eo_dat_srvs.get_value(); - return heap>({*this}, addr, std::move(iface)); + return heap>(*this, addr, std::move(iface), dat_srvs); } /** diff --git a/modules/remote/tests/remote_loopback.cpp b/modules/remote/tests/remote_loopback.cpp index d6f1e73..e1f3898 100644 --- a/modules/remote/tests/remote_loopback.cpp +++ b/modules/remote/tests/remote_loopback.cpp @@ -31,20 +31,38 @@ SAW_TEST("Remote Loopback RPC"){ auto eo_i64_srv = rmt.template data_listen(*addr); SAW_EXPECT(eo_i64_srv.is_value(), std::string{"Couldn't listen: "} + std::string{eo_i64_srv.get_error().get_category()}); auto& i64_srv = eo_i64_srv.get_value(); + + auto foo_func = [](data input) -> error_or> { + data rv; + rv.set(input.get() * 2); + return rv; + }; + + auto iface = interface_factory::create(std::move(foo_func)); - auto eo_rpc_srv = rmt.template rpc_listen(*addr, { - [](data input) -> error_or> { - data rv; - rv.set(input.get() * 2); - return rv; - } - }); + auto eo_rpc_srv = rmt.template rpc_listen(*addr, std::move(iface)); SAW_EXPECT(eo_rpc_srv.is_value(), std::string{"Couldn't listen: "} + std::string{eo_rpc_srv.get_error().get_category()}); auto& rpc_srv = eo_rpc_srv.get_value(); id id32{0u}; id id64{0u}; + data inp{21}; + + { + auto eo_send = u32_srv->send(inp, id32); + SAW_EXPECT(eo_send.is_value(), "Failed send."); + } + auto eo_called = rpc_srv->template call<"foo">(id32); + SAW_EXPECT(eo_called.is_value(), "Failed call."); + auto& called = eo_called.get_value(); + + { + auto eo_recv = i64_srv->receive(called); + SAW_EXPECT(eo_recv.is_value(), "Failed receive."); + auto& recv = eo_recv.get_value(); + SAW_EXPECT((recv.get() == 42), (std::string{"Wrong value received: "} + std::to_string(recv.get()))); + } } SAW_TEST("Remote Loopback Data"){ -- cgit v1.2.3