From 2cf3f586dfeb8a9c38f8a82eebf0d4236cea19b2 Mon Sep 17 00:00:00 2001 From: Anton Verburg <47820045+antonverburg@users.noreply.github.com> Date: Thu, 22 Aug 2024 19:34:50 +0200 Subject: [PATCH] Update lambda_magic.rst (#4187) Add some fixes in example code to make it more robust: - Prevent from buffer overflow - Add check on valid character --- cookbook/lambda_magic.rst | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/cookbook/lambda_magic.rst b/cookbook/lambda_magic.rst index 5aa4aaea6d..56496b4ad1 100644 --- a/cookbook/lambda_magic.rst +++ b/cookbook/lambda_magic.rst @@ -128,17 +128,24 @@ With this you can use automations or lambda to set switch or sensor states. if (readch > 0) { switch (readch) { - case '\n': // Ignore new-lines - break; - case '\r': // Return on CR + case '\n': + case '\r': // Return on CR or newline + buffer[pos] = 0; // Just to be sure, set last character 0 rpos = pos; pos = 0; // Reset position index ready for next time return rpos; default: - if (pos < len-1) { + if ((pos < len-1) && ( readch < 127 )) { // Filter on <127 to make sure it is a character buffer[pos++] = readch; buffer[pos] = 0; } + else + { + buffer[pos] = 0; // Just to be sure, set last character 0 + rpos = pos; + pos = 0; // Reset position index ready for next time + return rpos; + } } } // No end of line has been found, so return -1.