https://gcc.gnu.org/bugzilla/show_bug.cgi?id=79706
Bug ID: 79706
Summary: invalid delete[] expression doesn't cause substitution
failure
Product: gcc
Version: 6.3.1
Status: UNCONFIRMED
Severity: normal
Priority: P3
Component: c++
Assignee: unassigned at gcc dot gnu.org
Reporter: redi at gcc dot gnu.org
Target Milestone: ---
template<bool, typename = void> struct enable_if { };
template<typename T> struct enable_if<true, T> { using type = T; };
// Check that delete expression is well-formed:
template<bool _Array, typename _Yp>
auto
ck_delete(_Yp* __p)
-> typename enable_if<!_Array, decltype(delete __p)>::type;
// Check that delete[] expression is well-formed:
template<bool _Array, typename _Yp>
auto
ck_delete(_Yp* __p)
-> typename enable_if<_Array, decltype(delete[] __p)>::type
{ delete[] __p; }
struct A {
void operator delete(void*) = delete;
void operator delete[](void*) = delete;
};
auto f1 = &ck_delete<true, A>; // error expected here
int main()
{
f1(new A[1]);
}