#pragma once #include #include #include "remote_loopback_base.hpp" #include "transfer_loopback.hpp" namespace saw { template class remote_data { private: id id_; public: remote_data(const id& id): id_{id} {} /** * Wait until data arrives */ error_or> wait(wait_scope& wait); /** * Asynchronously wait for a result */ conveyor> on_receive(); }; /** * Client RPC reference structure */ template class rpc_client { /** * request the data from the remote */ template remote_data request_data(id data); /** @todo * Determine type based on Name */ /* template error_or< id< typename schema_member_type::type > > call(data_or_id inp); */ }; template class rpc_server { public: using InterfaceT = interface; private: const remote_address* addr_; InterfaceT iface_; public: rpc_server(const remote_address& addr__, InterfaceT iface__): addr_{&addr__}, iface_{std::move(iface__)} {} // error_or> // conveyor<> call }; }