xref: /llvm-project/libcxx/test/std/utilities/variant/variant.variant/implicit_ctad.pass.cpp (revision 64addd65210db59c8cb3794f792720e03e25b5af)
1c2df7076SLouis Dionne //===----------------------------------------------------------------------===//
2c2df7076SLouis Dionne //
3c2df7076SLouis Dionne // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4c2df7076SLouis Dionne // See https://llvm.org/LICENSE.txt for license information.
5c2df7076SLouis Dionne // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6c2df7076SLouis Dionne //
7c2df7076SLouis Dionne //===----------------------------------------------------------------------===//
8c2df7076SLouis Dionne 
9c2df7076SLouis Dionne // UNSUPPORTED: c++03, c++11, c++14
10c2df7076SLouis Dionne 
11c2df7076SLouis Dionne // <variant>
12c2df7076SLouis Dionne 
13c2df7076SLouis Dionne // template <class ...Types> class variant;
14c2df7076SLouis Dionne 
15c2df7076SLouis Dionne // Make sure that the implicitly-generated CTAD works.
16c2df7076SLouis Dionne 
17c2df7076SLouis Dionne // We make sure that it is not ill-formed, however we still produce a warning for
18c2df7076SLouis Dionne // this one because explicit construction from a variant using CTAD is ambiguous
19*64addd65SStephan T. Lavavej // (in the sense that the programmer intent is not clear).
20*64addd65SStephan T. Lavavej // ADDITIONAL_COMPILE_FLAGS(gcc-style-warnings): -Wno-ctad-maybe-unsupported
21c2df7076SLouis Dionne 
22c2df7076SLouis Dionne #include <variant>
23c2df7076SLouis Dionne 
24c2df7076SLouis Dionne #include "test_macros.h"
25c2df7076SLouis Dionne 
main(int,char **)26c2df7076SLouis Dionne int main(int, char**) {
27c2df7076SLouis Dionne   // This is the motivating example from P0739R0
28c2df7076SLouis Dionne   {
29c2df7076SLouis Dionne     std::variant<int, double> v1(3);
30c2df7076SLouis Dionne     std::variant v2 = v1;
31c2df7076SLouis Dionne     ASSERT_SAME_TYPE(decltype(v2), std::variant<int, double>);
32c2df7076SLouis Dionne   }
33c2df7076SLouis Dionne 
34c2df7076SLouis Dionne   {
35c2df7076SLouis Dionne     std::variant<int, double> v1(3);
36c2df7076SLouis Dionne     std::variant v2 = std::variant(v1); // Technically valid, but intent is ambiguous!
37c2df7076SLouis Dionne     ASSERT_SAME_TYPE(decltype(v2), std::variant<int, double>);
38c2df7076SLouis Dionne   }
39c2df7076SLouis Dionne 
40c2df7076SLouis Dionne   return 0;
41c2df7076SLouis Dionne }
42