Bruno Haible <br...@clisp.org> writes:

> I needed more infos about this bug fix (so I can know why the CI did
> not report it within three weeks). Since bug-gnulib was not in CC, I had
> to search. I updated this ChangeLog entry:

timespec-sub.c:38:12: error: operand argument to checked integer operation must 
be an integer type
      other than plain 'char', 'bool', bit-precise, or an enumeration ('bool' 
invalid)
   38 |   if (v == ckd_sub (&rs, rs, borrow))
      |            ^~~~~~~~~~~~~~~~~~~~~~~~~
/opt/homebrew/Cellar/llvm/18.1.8/lib/clang/18/include/stdckdint.h:38:54: note: 
expanded from macro
      'ckd_sub'
   38 | #define ckd_sub(R, A, B) __builtin_sub_overflow((A), (B), (R))
      |                                                      ^

Good to know thanks.

I was going to say that I wish it just treated bools as 0/1 but per the
documentation for ckd_* in C23 ยง 7.20 [1]:

    Both type2 and type3 shall be any integer type other than "plain"
    char, bool, a bit-precise integer type, or an enumerated type, and
    they need not be the same. *result shall be a modifiable lvalue of
    any integer type other than "plain" char, bool, a bit-precise
    integer type, or an enumerated type.

So I guess I can't complain.

Collin

[1] https://www.open-std.org/jtc1/sc22/wg14/www/docs/n3096.pdf

Reply via email to