There is no ambiguity / information loss in this conversion
Details
- Reviewers
alexfh aaron.ballman hokein - Commits
- rGd8851b5def46: [clang-tidy] Ignore bool -> single bit bitfield conversion in readability…
rCTE347671: [clang-tidy] Ignore bool -> single bit bitfield conversion in readability…
rL347671: [clang-tidy] Ignore bool -> single bit bitfield conversion in readability…
Diff Detail
- Repository
- rCTE Clang Tools Extra
- Build Status
Buildable 25366 Build 25365: arc lint + arc unit
Event Timeline
docs/clang-tidy/checks/readability-implicit-bool-conversion.rst | ||
---|---|---|
77–78 | I think it should only be allowed if the bit-field type is unsigned; signed bit-fields with a single bit are inherently not portable because you don't know if that bit represents a sign bit or a value bit (imagine a sign and magnitude integer representation). C++20 is changing this by standardizing on two's complement, but earlier versions of C++ (and currently, all versions of C) are still impacted, so another approach is to gate this on the language standard mode that's in effect. |
docs/clang-tidy/checks/readability-implicit-bool-conversion.rst | ||
---|---|---|
77–78 | I think it's the responsibility of a compiler using sign and magnitude representation to warn about signed single bit bitfields. |
LG
docs/clang-tidy/checks/readability-implicit-bool-conversion.rst | ||
---|---|---|
77–78 | I agree with Malcolm's argument. But if the concern is practical (i.e. if there's a user of this check, who's working with such compiler), we can add an option to enable the warning in this case. Any objections? |
docs/clang-tidy/checks/readability-implicit-bool-conversion.rst | ||
---|---|---|
77–78 | I think LLVM only supports two's complement backends currently anyway, so this is probably fine as-is. It was more a reaction to "there is no information loss" because there is information loss with the integer value, even in two's complement. It seems like clang is missing a warning that could handle this, however. https://godbolt.org/z/34xXIQ Boolean assignments are a bit of a different beast in that the bool is converted to integer as either 0 or 1, explicitly. It's a bit strange that you put in true (which would be converted to 1) and get back out -1 as the integer value, but it's not awful because of the usual "0 is false, nonzero is true" conversion behavior back to bool. |
I think it should only be allowed if the bit-field type is unsigned; signed bit-fields with a single bit are inherently not portable because you don't know if that bit represents a sign bit or a value bit (imagine a sign and magnitude integer representation).
C++20 is changing this by standardizing on two's complement, but earlier versions of C++ (and currently, all versions of C) are still impacted, so another approach is to gate this on the language standard mode that's in effect.