-
Notifications
You must be signed in to change notification settings - Fork 836
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Inhibit protocol names for not-included protocols #1853
Inhibit protocol names for not-included protocols #1853
Conversation
This looks quite messy, but I realize there is not much better solutions With that said, any chance we can switch to a macro that takes protocol name and enabled defines, which then expands to the #if #else #endif |
I'll add that
That only seems to be possible by using a 2-pass pre-processor trick, as a macro is a simple text replacement, and the #if #else #endif statements need to be on a separate line, but the macro will expand to a single line only. That seems to end in some snake-pit I'd prefer to avoid |
It screams "macro me" but I can't figure out how to do it cleanly (or at all). Let me think about this some more before proceeding. IRremoteESP8266/src/ir_NEC.cpp Lines 17 to 19 in 376fde2
|
That shouldn't be a problem, as by default everything is enabled, and we want to have the option to leave out as much unused code as possible by specifying what we don't need. If the code is still there, that's just our 'loss', but we won't use the protocol, so don't want to see it in the list. |
Could we generate this from the enums instead? It would still be committed as code, but should be easy to regenerate on any change. Could we have somehow have unit tests for any of these? My C brain is mush atm so please excuse my mistakes here... |
That condition is going to be part of a It would work like this: #if DECODE_RC5 || SEND_RC5
#define CD_STR_RC5 D_STR_RC5
#else
#define CD_STR_RC5 D_STR_UNSUPPORTED
#endif // if DECODE_RC5 || SEND_RC5 and then later: IRTEXT_CONST_BLOB_DECL(kAllProtocolNamesStr) {
D_STR_UNUSED "\x0"
CD_STR_RC5 "\x0"
//...
}; But that IMHO has somewhat of a maintenance disadvantage, as you are maintaining (nearly) the same list in 1 more place. |
And eventually I found this Reddit thread, by someone way more experienced in pre-processor macros then me. So we have a global mashup of these macros: (should IMHO be defined at some global level, just because of their usefulness 🤔) #define NOTHING
#define EXPAND(...) __VA_ARGS__
#define STUFF_P(a, ...) __VA_OPT__(a)
#define STUFF(...) STUFF_P(__VA_ARGS__)
#define VA_TEST_P(a,...) __VA_OPT__(NO)##THING
#define VA_TEST(...) VA_TEST_P(__VA_ARGS__)
#define NEGATE(a) VA_TEST(a,a)
#define COND_P(cond,a,b) STUFF(a,cond)STUFF(b,NEGATE(cond))
#define COND(cond,a,b) EXPAND(COND_P(cond, a, b)) so we eventually can write it like this: IRTEXT_CONST_BLOB_DECL(kAllProtocolNamesStr) {
D_STR_UNUSED "\x0"
COND(DECODE_RC5 || SEND_RC5, D_STR_RC5, D_STR_UNSUPPORTED) "\x0"
COND(DECODE_RC6 || SEND_RC6, D_STR_RC6, D_STR_UNSUPPORTED) "\x0"
//...
}; All I need now is a suggestion where to put those global macros 😃 |
That sounds tricky as it also means an enum value may have different int values on different builds. |
The enum stays. This is about generating the strings for those enums. |
The logic is eventually determined from the |
Maybe for inspiration, you can have a look at what I did here: https://github.com/letscontrolit/ESPEasy/blob/mega/lib/RN2483-Arduino-Library/src/rn2xx3_received_types.cpp This way you can have only one "ugly" part which is then the switch statement to loop over the enums and then call some macro to return the flash string version of that enum. If you need to have quotes on your strings due to spaces, you can also use some tricks like I did here with N.B. please use some toString() function to loop over the enum, with return type |
I'm worried about that too (i.e. one of the proposed solutions), I don't want the number/enum of a protocol to ever change. |
I like this approach better (I admit that is macro foo way above my skill level / pay grade :-). As for where to put it/them. Let's create a |
I suggest to use |
I did think that initially, so let's go with that. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Some automated lint/documentation checks failed:
src/IRmacros.h:17: Missing space after , [whitespace/comma] [3]
src/IRmacros.h:19: Missing space after , [whitespace/comma] [3]
src/IRmacros.h:20: Missing space after , [whitespace/comma] [3]
src/IRmacros.h:21: Missing space after , [whitespace/comma] [3]
src/IRmacros.h:26: Could not find a newline character at the end of the file. [whitespace/ending_newline] [5]
&
+ doxygen ./Doxyfile
/github/workspace/src/IRmacros.h:13: error: found documented #define NOTHING but ignoring it because ENABLE_PREPROCESSING is NO.
Other than that, it looks good to me for an initial starting point as any.
I spoke to soon. This breaks a lot of unit tests. |
Euhm, what's the preferred way to skip this Docygen message:
|
I must have dropped a ball somewhere, I'm on it. |
Not really fussed.
|
Yeah, it looks like a:
is needed.
|
It looks like an "off by one" problem. I'm guessing you missed a protocol. |
It's happening at or before RC5X I think |
While I have been able to compile all of this macro-fiesta for ESP8266 fine for the past days, this morning I had to clean my PIO global cache folders, and now I can't get the compiler to accept the
That should be available for the gnu++11 compiler, as configured for IRremoteESP8266 (AFAICS), but currently I can only build it for ESP32. |
…s!), regenerate IRtext.h
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me. All the tests pass .. so yay!
_v2.8.3 (20220915)_ **[Bug Fixes]** - Fix `#if` for DECODE_COOLIX48 (#1796) - Add missing `prev`s to `decodeToState()` (#1783) **[Features]** - Add `pause()` function to ESP32 when receiving. (#1871) - ARGO: Argo add `sendSensorTemp()` (#1858 #1859) - HAIER_AC160: Experimental detail support. (#1852 #1804) - BOSCH144: Add IRac class support (#1841) - Mitsubishi_AC: update left vane in `IRac` class (#1837) - Basic support for Daikin 312bit/39byte A/C protocol. (#1836 #1829) - Experimental basic support for Sanyo AC 152 bit protocol. (#1828 #1826) - GREE: Add model support for `YX1FSF`/Soleus Air Windown A/C (#1823 #1821) - Experimental basic support for Bosch 144bit protocol. (#1822 #1787) - Experimental basic support for TCL AC 96 bit protocol. (#1820 #1810) - Add basic support for clima-butler (52bit) RCS-SD43UWI (#1815 #1812) - TOTO: An experimental _(s)wipe_ at support for Toto Toilets. (#1811 #1806) - CARRIER_AC128: Experimental Basic support for Carrier AC 128bit protocol. (#1798 #1797) - HAIER_AC160: Add basic support for Haier 160bit protocol. (#1805 #1804) - DAIKIN: Add basic support for 200-bit Daikin protocol. (#1803 #1802) - FUJITSU: Improve handling of 10C Heat mode. (#1788 #1780) - FUJITSU: Improve handling of short (command only) messages. (#1784 #1780) **[Misc]** - Improve the `_IRREMOTEESP8266_VERSION_VAL` macro (#1875 #1870) - SONY: Update supported devices. (#1872) - SAMSUNG: Update supported devices (#1873) - NEC: Update supported devices (#1874) - Give IRmacros.h smaller scope to avoid impacting projects using IRremoteESP8266 (#1857 #1853 #1851) - Inhibit protocol names for not-included protocols (#1853 #1851) - Test out codeql static analysis (#1842) - Remove pylint disable=no-self-use (#1817) - Fujitsu General: update supported devices (#1813) - DAIKIN: Update supported devices (#1808 #1807) - Fujitsu: Update supported remote info. (#1801 #1794) - DAIKIN128: Update supported devices (#1754) - Voltas: Add link to manual for 122LZF A/C. (#1800 #1799 #1238) - Daikin128: Additional unit test. (#1795 #1754) - MIDEA: Update supported devices (#1791 #1790)
**_v2.8.3 (20220915)_** **[Bug Fixes]** - Fix `#if` for DECODE_COOLIX48 (#1796) - Add missing `prev`s to `decodeToState()` (#1783) **[Features]** - Add `pause()` function to ESP32 when receiving. (#1871) - ARGO: Argo add `sendSensorTemp()` (#1858 #1859) - HAIER_AC160: Experimental detail support. (#1852 #1804) - BOSCH144: Add IRac class support (#1841) - Mitsubishi_AC: update left vane in `IRac` class (#1837) - Basic support for Daikin 312bit/39byte A/C protocol. (#1836 #1829) - Experimental basic support for Sanyo AC 152 bit protocol. (#1828 #1826) - GREE: Add model support for `YX1FSF`/Soleus Air Windown A/C (#1823 #1821) - Experimental basic support for Bosch 144bit protocol. (#1822 #1787) - Experimental basic support for TCL AC 96 bit protocol. (#1820 #1810) - Add basic support for clima-butler (52bit) RCS-SD43UWI (#1815 #1812) - TOTO: An experimental _(s)wipe_ at support for Toto Toilets. (#1811 #1806) - CARRIER_AC128: Experimental Basic support for Carrier AC 128bit protocol. (#1798 #1797) - HAIER_AC160: Add basic support for Haier 160bit protocol. (#1805 #1804) - DAIKIN: Add basic support for 200-bit Daikin protocol. (#1803 #1802) - FUJITSU: Improve handling of 10C Heat mode. (#1788 #1780) - FUJITSU: Improve handling of short (command only) messages. (#1784 #1780) **[Misc]** - Improve the `_IRREMOTEESP8266_VERSION_VAL` macro (#1875 #1870) - SONY: Update supported devices. (#1872) - SAMSUNG: Update supported devices (#1873) - NEC: Update supported devices (#1874) - Give IRmacros.h smaller scope to avoid impacting projects using IRremoteESP8266 (#1857 #1853 #1851) - Inhibit protocol names for not-included protocols (#1853 #1851) - Test out codeql static analysis (#1842) - Remove pylint disable=no-self-use (#1817) - Fujitsu General: update supported devices (#1813) - DAIKIN: Update supported devices (#1808 #1807) - Fujitsu: Update supported remote info. (#1801 #1794) - DAIKIN128: Update supported devices (#1754) - Voltas: Add link to manual for 122LZF A/C. (#1800 #1799 #1238) - Daikin128: Additional unit test. (#1795 #1754) - MIDEA: Update supported devices (#1791 #1790)
It is a breaking change. Issue #1880 |
Resolves: #1851
To solve the request of how to determine at runtime what protocols are actually compiled in, after disabling unneeded protocols, I chose to replace the protocol name by a question mark (empty string can't work in a
\0x0
separated and\0x0\0x0
terminated string sequence). The shortest protocol name found so far is 'LG'.To avoid having to do a double/double check, for both IR and AC, and both SEND and RECEIVE protocols, and usually both SEND and RECEIVE for a used protocol are expected to be included, checking for a valid name seems appropriate.
Used this code in the project I'm working on, for building a list of available protocols:
The vectors are later used to populate a set of combo-boxes in the UI.
I recognize the somewhat less than ideal solution of not having a
bool
-returning function likeisProtocolAvailable(protocol)
, but to avoid the maintenance burden of having multiple places in code to reflect the list of active protocols, I've implemented this compromise.