xref: /llvm-project/libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/addressof.pass.cpp (revision dbe60caa922d5e4a30e4f335f33b2628dd82e3e7)
1e24ddb60SLouis Dionne //===----------------------------------------------------------------------===//
2e24ddb60SLouis Dionne //
3e24ddb60SLouis Dionne // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4e24ddb60SLouis Dionne // See https://llvm.org/LICENSE.txt for license information.
5e24ddb60SLouis Dionne // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6e24ddb60SLouis Dionne //
7e24ddb60SLouis Dionne //===----------------------------------------------------------------------===//
8e24ddb60SLouis Dionne 
9*dbe60caaSNikolas Klauser // UNSUPPORTED: c++03
10*dbe60caaSNikolas Klauser 
11e24ddb60SLouis Dionne // <functional>
12e24ddb60SLouis Dionne 
13e24ddb60SLouis Dionne // class function<R(ArgTypes...)>
14e24ddb60SLouis Dionne 
15e24ddb60SLouis Dionne // Make sure we can use std::function with a type that has a hostile overload
16e24ddb60SLouis Dionne // of operator&().
17e24ddb60SLouis Dionne 
18e24ddb60SLouis Dionne #include <functional>
19e24ddb60SLouis Dionne #include <cassert>
20e24ddb60SLouis Dionne 
21e24ddb60SLouis Dionne #include "operator_hijacker.h"
22e24ddb60SLouis Dionne 
23e24ddb60SLouis Dionne struct TrapAddressof : operator_hijacker {
operator ()TrapAddressof24e24ddb60SLouis Dionne     int operator()() const { return 1; }
25e24ddb60SLouis Dionne };
26e24ddb60SLouis Dionne 
main(int,char **)27e24ddb60SLouis Dionne int main(int, char**) {
28e24ddb60SLouis Dionne     std::function<int()> f = TrapAddressof();
29e24ddb60SLouis Dionne     assert(f() == 1);
30e24ddb60SLouis Dionne     return 0;
31e24ddb60SLouis Dionne }
32