Bugfix in LoRa-Uart
This commit is contained in:
parent
498d813624
commit
0967b6aa65
@ -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++;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user