Removed Tags file
Updated TODO file TcpClient: Added parameterless contructor, id is now -2 by default which is invalid, Added SendBytes method for C style arrays TcpServer: Added 2 CloseSocket function, one for TcpClient and another one for id, also added GetClientByID client is now declared on the stack in VoidNetClient Made Serializer code smaller, still need to integrate a compressor
This commit is contained in:
		| @ -6,7 +6,7 @@ template<typename T> const std::vector<byte> &Serializer::to_bytes(const T& obje | ||||
|  | ||||
| 	const byte *begin = reinterpret_cast<const byte*>(std::addressof(object)); | ||||
| 	const byte *end = begin + sizeof(T); | ||||
| 	std::copy(begin, end, std::begin(bytes)); | ||||
| 	std::copy(begin, end, bytes.begin()); | ||||
|  | ||||
| 	return bytes; | ||||
| } | ||||
| @ -14,10 +14,7 @@ template<typename T> const std::vector<byte> &Serializer::to_bytes(const T& obje | ||||
| template<typename T> const T& Serializer::from_bytes(const std::vector<byte> &bytes, T& object) | ||||
| { | ||||
| 	static_assert(std::is_trivially_copyable<T>::value, "not a TriviallyCopyable type"); | ||||
|  | ||||
| 	byte *begin_object = reinterpret_cast<byte*>(std::addressof(object)); | ||||
| 	std::vector<byte> bytes_vector(&bytes); | ||||
| 	std::copy(bytes_vector.begin(), bytes_vector.end(), begin_object); | ||||
| 	std::copy(bytes.begin(), bytes.end(), reinterpret_cast<const byte*>(std::addressof(object)); | ||||
|  | ||||
| 	return object; | ||||
| } | ||||
| @ -45,6 +45,10 @@ bool TcpClient::initialize(const std::string &ip, uint16 port) | ||||
| 	return initialized = true; | ||||
| } | ||||
|  | ||||
| TcpClient::TcpClient() | ||||
| { | ||||
| } | ||||
|  | ||||
| TcpClient::TcpClient(const SOCKET & socket) | ||||
| { | ||||
| 	tcp_socket = socket; | ||||
| @ -70,7 +74,12 @@ TcpClient::~TcpClient() | ||||
|  | ||||
| void TcpClient::Shutdown() | ||||
| { | ||||
| 	uint16 code = shutdown(tcp_socket, SD_SEND); | ||||
| 	NetworkMessage message; | ||||
| 	message.sender = id; | ||||
| 	message.distribution_mode = Server; | ||||
| 	message.tag = DISCONNECT; | ||||
| 	SendMessage(message); | ||||
| 	uint16 code = shutdown(tcp_socket, SD_BOTH); | ||||
| 	if (code == SOCKET_ERROR) | ||||
| 	{ | ||||
| 		if (Config::GetUsingConsole()) | ||||
| @ -148,7 +157,7 @@ const NetworkBuffer &TcpClient::receive_data_array() | ||||
| 	uint16 temp; | ||||
| 	if (DataAvailable(temp) && temp > 0) | ||||
| 	{ | ||||
| 		if (!recv(tcp_socket, reinterpret_cast<char*>(&buffer.header[0]), 4, 0)) | ||||
| 		if (!recv(tcp_socket, reinterpret_cast<char*>(buffer.header.data()), 4, 0)) | ||||
| 			//invalid header | ||||
| 			return NetworkBuffer(); | ||||
| 	} | ||||
| @ -156,7 +165,7 @@ const NetworkBuffer &TcpClient::receive_data_array() | ||||
| 		return NetworkBuffer(); | ||||
|  | ||||
| 	uint32 body_size = Utility::BitConverter::ToUint32(buffer.header); | ||||
| 	int16 body_received = recv(tcp_socket, reinterpret_cast<char*>(&buffer.body[0]), body_size, 0); | ||||
| 	int16 body_received = recv(tcp_socket, reinterpret_cast<char*>(buffer.body.data()), body_size, 0); | ||||
| 	if (body_received == SOCKET_ERROR || body_received != body_size || WSAGetLastError() != 0) | ||||
| 	{ | ||||
| 		//there was a problem receiving the body of the message or theres no body to receive | ||||
| @ -196,8 +205,9 @@ const NetworkMessage & TcpClient::ReceiveMessage() | ||||
| void TcpClient::send_network_message(const NetworkMessage &message, TcpClient *client) | ||||
| { | ||||
| 	NetworkBuffer buffer = NetworkMessage::EncodeMessage(message); | ||||
| 	int32 bytes_sent = send(client->tcp_socket, reinterpret_cast<char*>(&buffer.body[0]), Utility::BitConverter::ToUint32(buffer.header), 0); | ||||
| 	if (bytes_sent == SOCKET_ERROR || bytes_sent != Utility::BitConverter::ToInt32(buffer.header) || WSAGetLastError() != 0) | ||||
| 	int32 lenght = Utility::BitConverter::ToUint32(buffer.header); | ||||
| 	int32 bytes_sent = send(client->tcp_socket, reinterpret_cast<char*>(buffer.body.data()), lenght, 0); | ||||
| 	if (bytes_sent == SOCKET_ERROR || bytes_sent != lenght || WSAGetLastError() != 0) | ||||
| 	{ | ||||
| 		//something went wrong couldnt send anything/some data | ||||
| 	} | ||||
| @ -210,13 +220,22 @@ void TcpClient::SendMessage(const NetworkMessage &message) | ||||
|  | ||||
| void TcpClient::SendBytes(const std::vector<byte>& bytes) | ||||
| { | ||||
| 	int32 bytes_sent = send(tcp_socket, reinterpret_cast<const char*>(&bytes[0]), bytes.size(), 0); | ||||
| 	int32 bytes_sent = send(tcp_socket, reinterpret_cast<const char*>(bytes.data()), bytes.size(), 0); | ||||
| 	if (bytes_sent == SOCKET_ERROR || bytes_sent != bytes.size() || WSAGetLastError() != 0) | ||||
| 	{ | ||||
| 		//something went wrong couldnt send anything/some data | ||||
| 	} | ||||
| } | ||||
|  | ||||
| void TcpClient::SendBytes(byte * bytes, uint32 size) | ||||
| { | ||||
| 	int32 bytes_sent = send(tcp_socket, reinterpret_cast<const char*>(bytes), size, 0); | ||||
| 	if (bytes_sent == SOCKET_ERROR || bytes_sent != size || WSAGetLastError() != 0) | ||||
| 	{ | ||||
| 		//something went wrong couldnt send anything/some data | ||||
| 	} | ||||
| } | ||||
|  | ||||
| void TcpClient::SetOnDisconnectCallback(void(*func)(uint16)) | ||||
| { | ||||
| 	OnDisconnect = func; | ||||
|  | ||||
| @ -164,6 +164,8 @@ void TcpServer::SendMessage(const NetworkMessage & message) | ||||
| 	} | ||||
| 	case Server: // this will only send the message to the server | ||||
| 	{ | ||||
| 		if (message.tag == DISCONNECT) | ||||
| 			CloseSocket(message.sender); | ||||
| 		OnMessage(message); | ||||
| 		break; | ||||
| 	} | ||||
| @ -241,3 +243,31 @@ void TcpServer::AcceptConnection(TcpClient & client) | ||||
| 	Handshake handshake(client.GetID(), ConnectionCode::Accept); | ||||
| 	client.SendBytes(Handshake::EncodeHandshake(handshake)); | ||||
| } | ||||
|  | ||||
| void TcpServer::CloseSocket(TcpClient & client) | ||||
| { | ||||
| 	NetworkMessage message; | ||||
| 	message.sender = -1; | ||||
| 	message.distribution_mode = ID; | ||||
| 	message.destination_id = client.GetID(); | ||||
| 	message.tag = DISCONNECT; | ||||
| 	SendMessage(message); | ||||
| 	clients.erase(std::remove(clients.begin(), clients.end(), client), clients.end()); | ||||
| } | ||||
|  | ||||
| void TcpServer::CloseSocket(uint16 id) | ||||
| { | ||||
| 	TcpClient client = GetClientByID(id); | ||||
| 	if (client.GetID() != -2) | ||||
| 		CloseSocket(client); | ||||
| } | ||||
|  | ||||
| const TcpClient & TcpServer::GetClientByID(uint16 id) | ||||
| { | ||||
| 	for (std::vector<TcpClient>::iterator it = clients.begin(); it != clients.end(); ++it) | ||||
| 	{ | ||||
| 		if ((*it).GetID() == id) | ||||
| 			return *it; | ||||
| 	} | ||||
| 	return TcpClient(); | ||||
| } | ||||
|  | ||||
| @ -8,9 +8,9 @@ | ||||
|  | ||||
| bool VoidNetClientAPI::Connect(const std::string &ip, uint16 port) | ||||
| { | ||||
| 	client->SetIP(ip); | ||||
| 	client->SetPort(port); | ||||
| 	return client->Connect(); | ||||
| 	client.SetIP(ip); | ||||
| 	client.SetPort(port); | ||||
| 	return client.Connect(); | ||||
| } | ||||
|  | ||||
| void VoidNetClientAPI::SendMessageToServer(byte tag, byte subject, void *data) | ||||
| @ -47,7 +47,7 @@ void VoidNetClientAPI::SendMessage(byte distribution_mode, uint16 destination_id | ||||
| 	message.distribution_mode = distribution_mode; | ||||
| 	message.sender = id; | ||||
| 	message.destination_id = destination_id; | ||||
| 	client->SendMessage(message); | ||||
| 	client.SendMessage(message); | ||||
| } | ||||
|  | ||||
| void VoidNetClientAPI::Receive() | ||||
| @ -57,12 +57,10 @@ void VoidNetClientAPI::Receive() | ||||
|  | ||||
| void VoidNetClientAPI::process_all_data() | ||||
| { | ||||
| 	client->ReceiveMessages(); | ||||
| 	client.ReceiveMessages(); | ||||
| } | ||||
|  | ||||
| void VoidNetClientAPI::Disconnect() | ||||
| { | ||||
| 	Utility::Delete(client); | ||||
| 	receive = false; | ||||
| 	receive_thread.join(); | ||||
| } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 xX-TheDoctor-Xx
					xX-TheDoctor-Xx