xref: /llvm-project/libcxx/test/std/utilities/function.objects/refwrap/refwrap.assign/copy_assign.pass.cpp (revision eec04092d67b94f47439a9065b6bd4cd60165be2)
15a83710eSEric Fiselier //===----------------------------------------------------------------------===//
25a83710eSEric Fiselier //
357b08b09SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
457b08b09SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
557b08b09SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
65a83710eSEric Fiselier //
75a83710eSEric Fiselier //===----------------------------------------------------------------------===//
85a83710eSEric Fiselier 
95a83710eSEric Fiselier // <functional>
105a83710eSEric Fiselier 
115a83710eSEric Fiselier // reference_wrapper
125a83710eSEric Fiselier 
135a83710eSEric Fiselier // reference_wrapper& operator=(const reference_wrapper<T>& x);
145a83710eSEric Fiselier 
155a83710eSEric Fiselier #include <functional>
165a83710eSEric Fiselier #include <cassert>
175a83710eSEric Fiselier 
187fc6a556SMarshall Clow #include "test_macros.h"
197fc6a556SMarshall Clow 
205a83710eSEric Fiselier class functor1
215a83710eSEric Fiselier {
225a83710eSEric Fiselier };
235a83710eSEric Fiselier 
24*eec04092SArthur O'Dwyer struct convertible_to_int_ref {
25*eec04092SArthur O'Dwyer     int val = 0;
operator int&convertible_to_int_ref26*eec04092SArthur O'Dwyer     operator int&() { return val; }
operator int const&convertible_to_int_ref27*eec04092SArthur O'Dwyer     operator int const&() const { return val; }
28*eec04092SArthur O'Dwyer };
29*eec04092SArthur O'Dwyer 
305a83710eSEric Fiselier template <class T>
315a83710eSEric Fiselier void
test(T & t)325a83710eSEric Fiselier test(T& t)
335a83710eSEric Fiselier {
345a83710eSEric Fiselier     std::reference_wrapper<T> r(t);
355a83710eSEric Fiselier     T t2 = t;
365a83710eSEric Fiselier     std::reference_wrapper<T> r2(t2);
375a83710eSEric Fiselier     r2 = r;
385a83710eSEric Fiselier     assert(&r2.get() == &t);
395a83710eSEric Fiselier }
405a83710eSEric Fiselier 
f()415a83710eSEric Fiselier void f() {}
g()425a83710eSEric Fiselier void g() {}
435a83710eSEric Fiselier 
445a83710eSEric Fiselier void
test_function()455a83710eSEric Fiselier test_function()
465a83710eSEric Fiselier {
475a83710eSEric Fiselier     std::reference_wrapper<void ()> r(f);
485a83710eSEric Fiselier     std::reference_wrapper<void ()> r2(g);
495a83710eSEric Fiselier     r2 = r;
505a83710eSEric Fiselier     assert(&r2.get() == &f);
515a83710eSEric Fiselier }
525a83710eSEric Fiselier 
main(int,char **)532df59c50SJF Bastien int main(int, char**)
545a83710eSEric Fiselier {
555a83710eSEric Fiselier     void (*fp)() = f;
565a83710eSEric Fiselier     test(fp);
575a83710eSEric Fiselier     test_function();
585a83710eSEric Fiselier     functor1 f1;
595a83710eSEric Fiselier     test(f1);
605a83710eSEric Fiselier     int i = 0;
615a83710eSEric Fiselier     test(i);
625a83710eSEric Fiselier     const int j = 0;
635a83710eSEric Fiselier     test(j);
642df59c50SJF Bastien 
65*eec04092SArthur O'Dwyer #if TEST_STD_VER >= 11
66*eec04092SArthur O'Dwyer     convertible_to_int_ref convi;
67*eec04092SArthur O'Dwyer     test(convi);
68*eec04092SArthur O'Dwyer     convertible_to_int_ref const convic;
69*eec04092SArthur O'Dwyer     test(convic);
70*eec04092SArthur O'Dwyer 
71*eec04092SArthur O'Dwyer     {
72*eec04092SArthur O'Dwyer     using Ref = std::reference_wrapper<int>;
73*eec04092SArthur O'Dwyer     static_assert((std::is_assignable<Ref&, int&>::value), "");
74*eec04092SArthur O'Dwyer     static_assert((!std::is_assignable<Ref&, int>::value), "");
75*eec04092SArthur O'Dwyer     static_assert((!std::is_assignable<Ref&, int&&>::value), "");
76*eec04092SArthur O'Dwyer     }
77*eec04092SArthur O'Dwyer #endif
78*eec04092SArthur O'Dwyer 
792df59c50SJF Bastien   return 0;
805a83710eSEric Fiselier }
81