Created on 2017-08-18.00:00:00 last changed 77 months ago
[ 2018-08-20, Jonathan comments ]
This was reported to WG14 as N2207.
[ 2017-11 Albuquerque Wednesday night issues processing ]
Priority set to 2; status to Open
Jonathan is discussing this with WG14
The C standard says that the expression in an assert must have a scalar type, and implies (or at least allows) that the condition is tested by comparison to zero. C++ says that the expression is a constant subexpression if it can be contextually converted to bool. Those ways to test the condition are not equivalent.
It's possible to have expressions that meet the C++ requirements for a constant subexpression, but fail to meet the C requirements, and so don't compile.#include <stdlib.h> // A toy implementation of assert: #define assert(E) (void)(((E) != 0) || (abort(), 0)) struct X { constexpr explicit operator bool() const { return true; } }; constexpr bool f(const X& x) { assert(x); return true; }
C++ says that assert(x) is a constant subexpression, but as it doesn't have scalar type it's not even a valid expression.
I think either [cassert.syn] or [assertions.assert] should repeat the requirement from C that E has scalar type, either normatively or in a note. We should also consider whether "contextually converted to bool" is the right condition, or if we should use comparison to zero instead.History | |||
---|---|---|---|
Date | User | Action | Args |
2018-08-20 16:38:12 | admin | set | messages: + msg10085 |
2017-11-13 19:00:40 | admin | set | status: new -> open |
2017-11-09 15:13:04 | admin | set | messages: + msg9515 |
2017-08-18 00:00:00 | admin | create |