From 977ac8bce989285eaabc76c4ed8571ce5fd6793a Mon Sep 17 00:00:00 2001 From: Claudius 'keldu' Holeksa Date: Mon, 22 Jul 2024 17:44:27 +0200 Subject: wip --- modules/remote/c++/remote.hpp | 2 ++ modules/remote/c++/remote_loopback.hpp | 15 ++++++++++-- modules/remote/c++/transfer.hpp | 6 +++++ modules/remote/c++/transfer_loopback.hpp | 4 ++++ modules/remote/tests/remote_loopback.cpp | 39 ++++++++++++++++++++++---------- 5 files changed, 52 insertions(+), 14 deletions(-) (limited to 'modules/remote') diff --git a/modules/remote/c++/remote.hpp b/modules/remote/c++/remote.hpp index fd6f4e6..72c9cce 100644 --- a/modules/remote/c++/remote.hpp +++ b/modules/remote/c++/remote.hpp @@ -8,6 +8,8 @@ #include +#include "transfer.hpp" + namespace saw { /** * This class acts as a helper for rpc calls and representing data on the remote. diff --git a/modules/remote/c++/remote_loopback.hpp b/modules/remote/c++/remote_loopback.hpp index 76aab69..10ac79c 100644 --- a/modules/remote/c++/remote_loopback.hpp +++ b/modules/remote/c++/remote_loopback.hpp @@ -55,6 +55,16 @@ class rpc_client { template<> class remote_address { +private: + data addr_id_; +public: + remote_address(data addr_id__): + addr_id_{addr_id__} + {} + + const data& get_address_id() const { + return addr_id_; + } }; template @@ -75,12 +85,13 @@ public: template<> class remote { +private: public: /** * Resolves an address for the remote */ - error_or>> parse_address(){ - return heap>(); + error_or>> parse_address(data id){ + return heap>(id); } /** diff --git a/modules/remote/c++/transfer.hpp b/modules/remote/c++/transfer.hpp index 2fdd0b9..ea61d56 100644 --- a/modules/remote/c++/transfer.hpp +++ b/modules/remote/c++/transfer.hpp @@ -1,6 +1,12 @@ #pragma once namespace saw { +template +class i_data_server { +protected: + virtual ~i_data_server() = default; +}; + template class data_server; diff --git a/modules/remote/c++/transfer_loopback.hpp b/modules/remote/c++/transfer_loopback.hpp index abea83f..9d026f2 100644 --- a/modules/remote/c++/transfer_loopback.hpp +++ b/modules/remote/c++/transfer_loopback.hpp @@ -13,7 +13,11 @@ template class data_server, Encoding, rmt::Loopback> { private: typename impl::data_server_redux>::type>::type values_; + + ptr> remote_; public: + data_server(remote_address& addr) + /** * Get data from client */ diff --git a/modules/remote/tests/remote_loopback.cpp b/modules/remote/tests/remote_loopback.cpp index e78f646..2430029 100644 --- a/modules/remote/tests/remote_loopback.cpp +++ b/modules/remote/tests/remote_loopback.cpp @@ -21,20 +21,17 @@ using GroupedSchemas = saw::tmpl_group< SAW_TEST("Remote Loopback Data"){ using namespace saw; + event_loop loop; + wait_scope wait{loop}; + remote rmt; - auto eov = rmt.parse_address(); + auto eov = rmt.parse_address(0u); SAW_EXPECT(eov.is_value(), "Didn't parse correctly"); auto& val = eov.get_value(); - interface iface{ - [](data& foo){ - return foo.template cast_to(); - } - }; - - auto srv = data_server{}; - auto client = data_client{srv}; + auto srv = data_server{val}; + auto client = data_client{val}; data foo{421}; id sent_id = [&](){ @@ -43,9 +40,6 @@ SAW_TEST("Remote Loopback Data"){ return eov.get_value(); }(); - event_loop loop; - wait_scope wait{loop}; - { auto conv = client.receive(sent_id); auto eov = conv.take(); @@ -82,5 +76,26 @@ SAW_TEST("Remote Loopback Data"){ SAW_EXPECT(f_val, "Nullptr in find."); f_val->set(5u); } + { + auto conv = client.receive(alloc_id); + auto eov = conv.take(); + SAW_EXPECT(eov.is_value(), "Failed receive."); + SAW_EXPECT(eov.get_value().get() == 5u, "Wrong received value."); + } + + data> arr_meta{{128u}}; + + id> arr_alloc_id = [&](){ + auto eov = client.allocate>(arr_meta); + SAW_EXPECT(eov.is_value(), "Failed send."); + return eov.get_value(); + }(); + { + auto eov = client.find(arr_alloc_id); + SAW_EXPECT(eov.is_value(), "Failed find."); + auto& f_val = eov.get_value(); + SAW_EXPECT(f_val, "Nullptr in find."); + SAW_EXPECT(f_val->size() == arr_meta.at(0).get(), "Wrong initialized size."); + } } } -- cgit v1.2.3