summaryrefslogtreecommitdiff
path: root/modules/codec/c++/rpc.hpp
blob: 9f59455f8ce32ffd167fa8de5169e58809cbc001 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#pragma once

namespace saw {

/**
 *
 */
template<typename T, typename Remote>
class remote_data {
private:
	id<T> id_;
public:
	remote_data(const id<T>& id):
		id_{id}
	{}

	/**
	 * Wait until data arrives
	 */
	error_or<data<T>> wait(wait_scope& wait);

	/**
	 * Asynchronously wait for a result
	 */
	conveyor<data<T>> on_receive();
};

/**
 * Client RPC reference structure
 */
template<typename T, typename Iface>
class rpc_client {
	/**
	 * request the data from the remote
	 */
	template<typename IdT>
	remote_data<IdT> request_data(id<IdT> data);
		
	/**
	 * Determine type based on Name
	 */
	template<string_literal Name>
	error_or<
		id<
			typename schema_member_type<Name, Iface>::type
		>
	> call(data_or_id<Input> inp);
};

/**
 * Implementation of a remote server on the backend
 */
template<typename T, typename Iface>
class rpc_server {
private:
	interface<Iface> iface_;
public:
	rpc_server(interface<Iface> iface):
		iface_{std::move(iface)}
	{}
};

/**
 * Representation of a remote.
 * Partially similar to a network address
 */
template<typename T>
class remote_address {
	static_assert(always_false<T>, "Type of remote not supported");


};

/**
 * Reference Backend structure
 */
template<typename T>
class remote_context {
	static_assert(always_false<T>, "Type of backend not supported");

	/**
	 * Resolves an address on the remote
	 */
	conveyor<remote_address<T>> resolve_address();

	/**
	 * Connect to a remote
	 */
	template<typename Iface>
	conveyor<rpc_client<T,Iface>> connect(const remote_address<T>& addr);

	/**
	 * Start listening
	 */
	template<typename Iface>
	rpc_server<T,Iface> listen();
};
}