* c-cppbuiltin.c (c_cpp_builtins): Define __cpp_explicit_bool. * call.c (add_template_candidate_real): Return if the declaration is explicit and we're only looking for non-converting constructor. * cp-tree.h (lang_decl_fn): Add has_dependent_explicit_spec_p bit. (DECL_HAS_DEPENDENT_EXPLICIT_SPEC_P): New macro. (cp_decl_specifier_seq): Add explicit_specifier field. (build_explicit_specifier, store_explicit_specifier): Declare. * decl.c (grokdeclarator): Call store_explicit_specifier. (build_explicit_specifier): New function. * parser.c (cp_parser_function_specifier_opt) <case RID_EXPLICIT>: Parse C++20 explicit(bool). * pt.c (store_explicit_specifier, lookup_explicit_specifier): New. (tsubst_function_decl): Handle explicit(dependent-expr). * g++.dg/cpp2a/explicit1.C: New test. * g++.dg/cpp2a/explicit10.C: New test. * g++.dg/cpp2a/explicit11.C: New test. * g++.dg/cpp2a/explicit12.C: New test. * g++.dg/cpp2a/explicit13.C: New test. * g++.dg/cpp2a/explicit2.C: New test. * g++.dg/cpp2a/explicit3.C: New test. * g++.dg/cpp2a/explicit4.C: New test. * g++.dg/cpp2a/explicit5.C: New test. * g++.dg/cpp2a/explicit6.C: New test. * g++.dg/cpp2a/explicit7.C: New test. * g++.dg/cpp2a/explicit8.C: New test. * g++.dg/cpp2a/explicit9.C: New test. * testsuite/20_util/any/cons/explicit.cc: Adjust dg-error. * testsuite/20_util/pair/cons/explicit_construct.cc: Likewise. * testsuite/20_util/tuple/cons/explicit_construct.cc: Likewise. From-SVN: r265641
42 lines
648 B
C
42 lines
648 B
C
// P0892R2
|
|
// { dg-do compile }
|
|
// { dg-options "-std=c++2a" }
|
|
|
|
template<int T = 1>
|
|
struct S {
|
|
explicit(T) operator int();
|
|
};
|
|
|
|
template<typename T, int N>
|
|
struct R {
|
|
explicit(N) operator T();
|
|
};
|
|
|
|
template<typename T>
|
|
struct U {
|
|
explicit((T) 1.0) operator T();
|
|
};
|
|
|
|
int
|
|
main ()
|
|
{
|
|
S s;
|
|
int i1 = s; // { dg-error "cannot convert" }
|
|
S<true> s2;
|
|
int i2 = s2; // { dg-error "cannot convert" }
|
|
S<false> s3;
|
|
int i3 = s3;
|
|
int i4{s};
|
|
int i5{s2};
|
|
int i6{s3};
|
|
|
|
R<int, true> r;
|
|
int i7 = r; // { dg-error "cannot convert" }
|
|
R<int, false> r2;
|
|
int i8 = r2;
|
|
|
|
U<int> u;
|
|
int i9 = u; // { dg-error "cannot convert" }
|
|
int i10{u};
|
|
}
|