From de1f2c4b160f64f9d49ce9cadecb22dfdd04b945 Mon Sep 17 00:00:00 2001 From: griffi-gh Date: Wed, 1 Feb 2023 03:24:06 +0100 Subject: [PATCH] client --- kubi-udp/src/client.rs | 22 +++++++++++++--------- 1 file changed, 13 insertions(+), 9 deletions(-) diff --git a/kubi-udp/src/client.rs b/kubi-udp/src/client.rs index e98a8b9..f2be789 100644 --- a/kubi-udp/src/client.rs +++ b/kubi-udp/src/client.rs @@ -5,31 +5,35 @@ use std::{ use bincode::{Encode, Decode}; use crate::{BINCODE_CONFIG, packet::ClientPacket}; -pub struct Client where T: Encode + Decode { +pub struct Client where S: Encode + Decode, R: Encode + Decode { socket: UdpSocket, - _marker: PhantomData + _s: PhantomData, + _r: PhantomData, } -impl Client where T: Encode + Decode { +impl Client where S: Encode + Decode, R: Encode + Decode { pub fn connect(addr: SocketAddr) -> anyhow::Result { let bind_addr: SocketAddr = "127.0.0.1:0".parse().unwrap(); let socket = UdpSocket::bind(bind_addr)?; socket.set_nonblocking(true)?; socket.connect(addr)?; - Ok(Self { + let client = Self { socket, - _marker: PhantomData - }) + _s: PhantomData, + _r: PhantomData, + }; + client.send_packet(&ClientPacket::Connect)?; + Ok(client) } - fn send_packet(&self, packet: &ClientPacket) -> anyhow::Result<()> { + fn send_packet(&self, packet: &ClientPacket) -> anyhow::Result<()> { let bytes = bincode::encode_to_vec(packet, BINCODE_CONFIG)?; self.socket.send(&bytes)?; Ok(()) } - pub fn send(&self, message: T) -> anyhow::Result<()> { + pub fn send_message(&self, message: S) -> anyhow::Result<()> { self.send_packet(&ClientPacket::Data(message))?; Ok(()) } - pub fn disconnect(&self) -> anyhow::Result<()> { + pub fn disconnect(self) -> anyhow::Result<()> { self.send_packet(&ClientPacket::Disconnect)?; Ok(()) }