-
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
rewrite ir_Gree #1210
rewrite ir_Gree #1210
Conversation
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.
Hey ya @siriuslzx,
First off, this is great. I really appreciate the effort. While this works fine on most CPU architectures and compilers, it doesn't work on all of them.
I was initially thrilled to find the "Bit fields" aspects of C and C++ myself, however there are reports of them not producing the same results with different compilers even for the same architecture.
See:
Notes
The following properties of bit fields are implementation-defined
The value that results from assigning or initializing a signed bit field with a value out of range, or from incrementing a signed bit field past its range.
Everything about the actual allocation details of bit fields within the class object
For example, on some platforms, bit fields don't straddle bytes, on others they do
Also, on some platforms, bit fields are packed left-to-right, on others right-to-left
https://en.cppreference.com/w/cpp/language/bit_field
So, it is with a very heavy heart that I'll probably have to decline this PR to try to keep the code as portable as possible. It really is a nice & nice work, and I really want to use it myself.
If you know of a good/clean/nice way to add a check for if the compiler/platform etc decides to swap on us, then I'd entertain it. I'd probably also re-write all the others too.
I'll also need to check if it saves flash space, or costs more too. We get a lot of downward pressure from major library users to reduce space where we can. It sometimes trumps code-readability. :-/
I'm glad you like it although you won't accept this PR. I test it with Arduino IDE 1.8.13, on WEMOS D1 mini and it works well. Since you say you need to check the flash space, I compile the example TrunOnGreeAC twice and the result is as follow: the master version: the bit field version: |
What is the probability that we can write a "startup test" to make sure it works? But then the question becomes, what should happen if it finds issues? |
I personally haven't hit it being "different". All the platforms I have use regularly, it (bit fields) seem to work "as we want it to" on.
vs
So it appears the bit field one saves ~100 bytes for a "detailed" protocol. So, all up we might save 2-4k over the entire library. |
saving about 2-4k would be a great step. The project owner of Tasmota is always asking @s-hadinger about the code size increase when updating to a new version. Without your great lib Tasmota would be not Tasmota ;-) |
I'm fully aware of how desirable reducing the resources is. |
@siriuslzx I haven't forgotten this. Just trying to find some spare time come up with a safe solution for this so it doesn't bite us later. i.e. I really want to merge it and go this way. |
I will take part in the work after you merge this |
* Pave the way for us being able to use Bit Fields reliably. (They are not fully portable) * Add `lowLevelSanityCheck()` function to do bit field and endianness checks. * Add a unit test for it. i.e. capture problems in unit tests. * Add checks for it in `IRrecvDumpV[2|3]` and `IRMQTTServer` so we can catch it at run time. * Bump IRMQTTServer version number. Pre-work for #1210
* Pave the way for us being able to use Bit Fields reliably. (They are not fully portable) * Add `lowLevelSanityCheck()` function to do bit field and endianness checks. * Add a unit test for it. i.e. capture problems in unit tests. * Add checks for it in `IRrecvDumpV[2|3]` and `IRMQTTServer` so we can catch it at run time. * Bump `IRMQTTServer` version number. Pre-work for #1210
I've added some sanity that should trigger if we hit some problem with the use of Bit Fields on incompatible environments. When the travis checks finish, I'll merge this PR, and we can start on moving all the protocols over to Bit Fields. |
_v2.7.10 (20200831)_ **[BREAKING CHANGES]** - move SPIFFS to LittleFS for ESP8266 (#1182 #1226) - Daikin176: Change & increase operating mode values. (#1233 #1235) **[Bug Fixes]** - TOSHIBA_AC: not turning off when using `IRac` class. (#1250 #1251) - Haier: change position of Fan speed bits. (#1246 #1247) **[Features]** - Voltas: Add detailed support for Voltas A/Cs (#1238 #1248) - Add support for Metz protocol. (#1241 #1242) - Basic support for Voltas A/C protocol (#1238 #1243) - Add low level bit formatting sanity checks. (#1232) **[Misc]** - Rewrite Airwell by using bit fields (#1254) - Rewrite Haier YRW02 using bit fields (#1253) - rewrite Haier HSU07-HEA03 (#1246 #1247) - rewrite ir_Gree & ir_Midea by using bit field (#1240) - Incorrect usage of `assert()` (#1244 #1245 #1232) - rewrite Gree (#1210)
## v2.7.10 release _v2.7.10 (20200831)_ **[BREAKING CHANGES]** - move SPIFFS to LittleFS for ESP8266 (#1182 #1226) - Daikin176: Change & increase operating mode values. (#1233 #1235) **[Bug Fixes]** - TOSHIBA_AC: not turning off when using `IRac` class. (#1250 #1251) - Haier: change position of Fan speed bits. (#1246 #1247) **[Features]** - Voltas: Add detailed support for Voltas A/Cs (#1238 #1248) - Add support for Metz protocol. (#1241 #1242) - Basic support for Voltas A/C protocol (#1238 #1243) - Add low level bit formatting sanity checks. (#1232) **[Misc]** - Rewrite Airwell by using bit fields (#1254) - Rewrite Haier YRW02 using bit fields (#1253) - rewrite Haier HSU07-HEA03 (#1246 #1247) - rewrite ir_Gree & ir_Midea by using bit field (#1240) - Incorrect usage of `assert()` (#1244 #1245 #1232) - rewrite Gree (#1210)
The code changes mention have now been included in the newly released v2.7.10 of the library. |
make ir_Gree easier to understand and maintain