From 88e207e137b04ec2d0f80745d850e117a796c819 Mon Sep 17 00:00:00 2001 From: Simon Hyde Date: Tue, 7 Nov 2023 12:52:13 +0000 Subject: [PATCH] retrieve_Switch accept values from display_SWITCH display_SWITCH prints with %02X, so retrieve_Switch ought to accept values made of 2 nibbles too, so make retrieve_Switch call retrieve_byte --- RFLink/4_Display.cpp | 2 +- RFLink/4_Display.h | 2 +- RFLink/Plugins/Plugin_004.c | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/RFLink/4_Display.cpp b/RFLink/4_Display.cpp index fa629f7a..3916cce8 100644 --- a/RFLink/4_Display.cpp +++ b/RFLink/4_Display.cpp @@ -512,7 +512,7 @@ boolean retrieve_ID(unsigned long &ul_ID) boolean retrieve_Switch(byte &b_Switch) { - return retrieve_nibble(b_Switch, "SWITCH="); + return retrieve_byte(b_Switch, "SWITCH="); } boolean retrieve_Command(byte &b_Cmd) diff --git a/RFLink/4_Display.h b/RFLink/4_Display.h index 42e6e762..0adef1a8 100644 --- a/RFLink/4_Display.h +++ b/RFLink/4_Display.h @@ -106,7 +106,7 @@ boolean retrieve_byte(byte &, const char* = NULL); // calls retrieve_hexNumber( boolean retrieve_nibble(byte &, const char* = NULL); // calls retrieve_hexNumber(, 1, ) boolean retrieve_ID(unsigned long &); // calls retrieve_long(, "ID=") and limits the value to 0x03FFFFFF (26 bits) -boolean retrieve_Switch(byte &); // calls retrieve_nibble(, "SWITCH=") +boolean retrieve_Switch(byte &); // calls retrieve_byte(, "SWITCH=") boolean retrieve_Command(byte &); // calls retrieve_command(, "CMD=") boolean retrieve_End(); // returns true if the token "pointer" is at the end of the input string diff --git a/RFLink/Plugins/Plugin_004.c b/RFLink/Plugins/Plugin_004.c index 78204fc2..1e501699 100644 --- a/RFLink/Plugins/Plugin_004.c +++ b/RFLink/Plugins/Plugin_004.c @@ -198,7 +198,7 @@ boolean PluginTX_004(byte function, const char *string) bitstream = (ID_bitstream << 6); // 26 bits on top - bitstream |= Switch_bitstream; // Complete transmitted address + bitstream |= Switch_bitstream & 0xF; // Complete transmitted address // bitstream &= 0xFFFFFFCF; // Bit 4 and 5 are left for cmd bitstream |= (Cmd_bitstream << 4);