Bugfix in LoRa-Uart

This commit is contained in:
Marcel Peterkau 2023-05-28 19:36:39 +02:00
parent 498d813624
commit 0967b6aa65

View File

@ -68,6 +68,7 @@ bool InitLoRa(void (*MPinHelper)(int, int))
}
#elif defined(FEATURE_ENABLE_UARTLORA)
SerialLoRa.begin(9600);
returnval = true;
#endif
return returnval;
}
@ -94,35 +95,26 @@ void LoRa_Process()
}
#elif defined(FEATURE_ENABLE_UARTLORA)
char packageInput[16];
bool packageRecieved = false;
unsigned int bufferPtr = 0;
static char packageInput[32];
static bool packageRecieved = false;
static unsigned int bufferPtr = 0;
if (SerialLoRa.available() && packageRecieved == false)
while (SerialLoRa.available() && packageRecieved == false)
{
while (bufferPtr < sizeof(packageInput))
if (bufferPtr < sizeof(packageInput) - 1)
{
packageInput[bufferPtr] = SerialLoRa.read();
packageInput[bufferPtr + 1] = 0; // always terminate String
if (packageInput[bufferPtr] == '\n')
{
packageInput[bufferPtr] = 0; // terminate String
packageRecieved = true;
bufferPtr = 0;
Debug_pushMessage("Got LoRa UART: %s\n", packageInput);
break;
}
else if ((packageInput[bufferPtr] >= 0x30) || (packageInput[bufferPtr] <= 0x5A)) // only accept Numbers, UpperCase-Letters and some special chars
{
if (bufferPtr < sizeof(packageInput) - 1)
{
bufferPtr++;
}
else
{
packageInput[bufferPtr] = 0; // terminate String, bc Buffer is full (package to long)
packageRecieved = true; // send it anyway to the parser
Debug_pushMessage("Got LoRa UART: %s\n", packageInput);
break;
}
bufferPtr++;
}
}
}