Use buffer for zerstückelte Messages

This commit is contained in:
Tim Zeuner 2023-02-07 21:20:49 +01:00
parent a920aefa54
commit 65516babfc
2 changed files with 55 additions and 12 deletions

View File

@ -2,6 +2,7 @@
LFR_Socket::LFR_Socket(ExceptionCallback cb): cb(cb) LFR_Socket::LFR_Socket(ExceptionCallback cb): cb(cb)
{ {
bufferIterator = std::begin(buffer);
if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1) if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1)
{ {
throw std::runtime_error("Failed opening the socket"); throw std::runtime_error("Failed opening the socket");
@ -66,7 +67,7 @@ void LFR_Socket::createThread()
bool connected = false; bool connected = false;
while(true) while(true)
{ {
LFR_Socket::LFR_Telegram telegram; LFR_Socket::LFR_Telegram telegram = {};
bool received = false; bool received = false;
if(!stop && !listeners.empty()) if(!stop && !listeners.empty())
{ {
@ -91,32 +92,46 @@ void LFR_Socket::createThread()
} }
else else
{ {
//std::cout << "accepted connection" << std::endl; std::cout << "accepted connection" << std::endl;
pollfds[1].fd = new_socket; pollfds[1].fd = new_socket;
connected = true; connected = true;
} }
} }
else if (connected && pollfds[0].revents & POLLIN) else if (connected && pollfds[0].revents & POLLIN)
{ {
//std::cout << "second connection incoming" << std::endl; std::cout << "second connection incoming" << std::endl;
int tmp_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t *)&addrlen); int tmp_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t *)&addrlen);
close(tmp_socket); close(tmp_socket);
//std::cout << "second connection closed" << std::endl; std::cout << "second connection closed" << std::endl;
} }
else if (pollfds[1].revents & POLLIN) else if (pollfds[1].revents & POLLIN)
{ {
bytes_received = recv(new_socket, buffer, sizeof(buffer), 0); LFR_Telegram tmpBuffer = {0};
if (bytes_received > 0) bytesReceived = recv(new_socket, tmpBuffer, sizeof(tmpBuffer), 0);
if (bytesReceived > 0)
{ {
received = true; if(bufferIterator - std::begin(buffer) + bytesReceived > 1024)
std::copy(std::begin(buffer), std::end(buffer), std::begin(telegram)); {
//std::cout << "message received" << std::endl; //Too long for buffer. Clear it.
std::fill(std::begin(buffer), std::end(buffer), 0);
bufferIterator = std::begin(buffer);
} }
else if(bytes_received == 0) bufferIterator = std::copy_if(
std::begin(tmpBuffer),
std::begin(tmpBuffer)+bytesReceived,
bufferIterator,
[](char c){
return(c != '\n' && c != '\r');
});
//std::cout << "bytes received: " << bytesReceived << std::endl;
//received = true;
}
else if(bytesReceived == 0)
{ {
connected = false; connected = false;
close(pollfds[1].fd); close(pollfds[1].fd);
//std::cout << "connection closed by peer" << std::endl; std::cout << "connection closed by peer" << std::endl;
} }
} }
} }
@ -131,6 +146,32 @@ void LFR_Socket::createThread()
} }
} }
// Search the buffer for the start of a telegram
char *telegramStart = NULL;
telegramStart = strstr(buffer, "aa");
if(telegramStart && telegramStart != std::begin(buffer)) {
//Move the content of the buffer
auto delta = bufferIterator - telegramStart;
std::copy(telegramStart, std::end(buffer), std::begin(buffer));
bufferIterator = std::begin(buffer) + delta;
}
// Search the buffer for the end of a telegram
char *telegramEnd = NULL;
telegramEnd = strstr(buffer, "zz");
if(telegramEnd && telegramStart && telegramEnd-telegramStart>2) {
std::copy(telegramStart+2, telegramEnd, telegram);
received = true;
std::copy(telegramEnd+2, std::end(buffer), std::begin(buffer));
bufferIterator = std::begin(buffer);
}
else if(telegramEnd && telegramStart && telegramEnd-telegramStart<=2)
{
//Got an empty telegram
std::copy(telegramEnd, std::end(buffer), std::begin(buffer));
bufferIterator = std::begin(buffer);
}
//Invoke the callback method (ListenerPair second -> ListenerCallback) //Invoke the callback method (ListenerPair second -> ListenerCallback)
if (received) if (received)
{ {

View File

@ -13,6 +13,7 @@
#include <string> #include <string>
#include <algorithm> #include <algorithm>
#include <exception> #include <exception>
#include <cstring>
class LFR_Socket class LFR_Socket
{ {
@ -31,11 +32,12 @@ private:
std::unique_ptr<std::thread> thread; std::unique_ptr<std::thread> thread;
mutable std::mutex mutex; mutable std::mutex mutex;
int server_fd, new_socket, bytes_received; int server_fd, new_socket, bytesReceived;
struct sockaddr_in address; struct sockaddr_in address;
int opt = 1; int opt = 1;
int addrlen = sizeof(address); int addrlen = sizeof(address);
char buffer[1024] = {0}; char buffer[1024] = {0};
char* bufferIterator;
//void provideOutput(Mat originalImage, Mat processedImage, const FrameData& frameData, const Rect& roi); //void provideOutput(Mat originalImage, Mat processedImage, const FrameData& frameData, const Rect& roi);