aboutsummaryrefslogtreecommitdiff
path: root/src/network.cpp
diff options
context:
space:
mode:
authorDeterminant <[email protected]>2019-06-05 15:20:23 -0400
committerDeterminant <[email protected]>2019-06-05 15:20:23 -0400
commitf7050c145e81a70be85bb0287044abdfa7ba444f (patch)
tree9780cf160876e2d26b11cc4fef15859d7068ab03 /src/network.cpp
parent14832c4ffec02b47d953a1c6d70576070ce74935 (diff)
finish PeerNetwork C APIs
Diffstat (limited to 'src/network.cpp')
-rw-r--r--src/network.cpp58
1 files changed, 55 insertions, 3 deletions
diff --git a/src/network.cpp b/src/network.cpp
index 9fc07fe..869dd40 100644
--- a/src/network.cpp
+++ b/src/network.cpp
@@ -6,6 +6,8 @@ using namespace salticidae;
extern "C" {
+// MsgNetwork
+
msgnetwork_config_t *msgnetwork_config_new() {
return new msgnetwork_config_t();
}
@@ -20,11 +22,11 @@ void msgnetwork_free(const msgnetwork_t *self) { delete self; }
bool msgnetwork_send_msg(msgnetwork_t *self,
const msg_t *msg, const msgnetwork_conn_t *conn) {
- return self->send_msg(*msg, *conn);
+ return self->_send_msg(*msg, *conn);
}
msgnetwork_conn_t *msgnetwork_connect(msgnetwork_t *self, const netaddr_t *addr) {
- return new msgnetwork_t::conn_t(self->connect(*addr));
+ return new msgnetwork_conn_t(self->connect(*addr));
}
void msgnetwork_listen(msgnetwork_t *self, const netaddr_t *listen_addr) {
@@ -35,7 +37,7 @@ void msgnetwork_reg_handler(msgnetwork_t *self,
_opcode_t opcode,
msgnetwork_msg_callback_t cb) {
self->set_handler(opcode,
- [cb](const msgnetwork_t::Msg &msg, const msgnetwork_t::conn_t &conn) {
+ [cb](const msgnetwork_t::Msg &msg, const msgnetwork_conn_t &conn) {
cb(&msg, &conn);
});
}
@@ -61,6 +63,56 @@ netaddr_t *msgnetwork_conn_get_addr(const msgnetwork_conn_t *conn) {
return new netaddr_t((*conn)->get_addr());
}
+// PeerNetwork
+
+peernetwork_config_t *peernetwork_config_new() {
+ return new peernetwork_config_t();
+}
+
+void peernetwork_config_free(const peernetwork_config_t *self) { delete self; }
+
+peernetwork_t *peernetwork_new(const eventcontext_t *ec, const peernetwork_config_t *config) {
+ return new peernetwork_t(*ec, *config);
+}
+
+void peernetwork_free(const peernetwork_t *self) { delete self; }
+
+void peernetwork_add_peer(peernetwork_t *self, const netaddr_t *paddr) {
+ self->add_peer(*paddr);
+}
+
+bool peernetwork_has_peer(const peernetwork_t *self, const netaddr_t *paddr) {
+ return self->has_peer(*paddr);
+}
+
+const peernetwork_conn_t *get_peer_conn(const peernetwork_t *self,
+ const netaddr_t *paddr) {
+ return new peernetwork_conn_t(self->get_peer_conn(*paddr));
+}
+
+msgnetwork_t *peernetwork_as_msgnetwork(peernetwork_t *self) { return self; }
+
+msgnetwork_conn_t *msgnetwork_conn_new_from_peernetwork_conn(const peernetwork_conn_t *conn) {
+ return new msgnetwork_conn_t(*conn);
+}
+
+void peernetwork_send_msg(peernetwork_t *self,
+ msg_t * _moved_msg, const netaddr_t *paddr) {
+ self->_send_msg(std::move(*_moved_msg), *paddr);
+ delete _moved_msg;
+}
+
+void peernetwork_multicast_msg(peernetwork_t *self,
+ msg_t *_moved_msg,
+ const netaddr_t *paddrs, size_t npaddrs) {
+ self->_multicast_msg(std::move(*_moved_msg), paddrs, npaddrs);
+ delete _moved_msg;
+}
+
+void peernetwork_listen(peernetwork_t *self, const netaddr_t *listen_addr) {
+ self->listen(*listen_addr);
+}
+
}
#endif