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 
9e24ddb60SLouis Dionne // <functional>
10e24ddb60SLouis Dionne 
11e24ddb60SLouis Dionne // class function<R(ArgTypes...)>
12e24ddb60SLouis Dionne 
13e24ddb60SLouis Dionne // This test runs in C++03, but we have deprecated using std::function in C++03.
14*c475e31aSNikolas Klauser // ADDITIONAL_COMPILE_FLAGS: -D_LIBCPP_DISABLE_DEPRECATION_WARNINGS -D_LIBCPP_ENABLE_CXX03_FUNCTION
15e24ddb60SLouis Dionne 
16e24ddb60SLouis Dionne // Make sure we can use std::function with a type that has a hostile overload
17e24ddb60SLouis Dionne // of operator&().
18e24ddb60SLouis Dionne 
19e24ddb60SLouis Dionne #include <functional>
20e24ddb60SLouis Dionne #include <cassert>
21e24ddb60SLouis Dionne 
22e24ddb60SLouis Dionne #include "operator_hijacker.h"
23e24ddb60SLouis Dionne 
24e24ddb60SLouis Dionne struct TrapAddressof : operator_hijacker {
operator ()TrapAddressof25e24ddb60SLouis Dionne     int operator()() const { return 1; }
26e24ddb60SLouis Dionne };
27e24ddb60SLouis Dionne 
main(int,char **)28e24ddb60SLouis Dionne int main(int, char**) {
29e24ddb60SLouis Dionne     std::function<int()> f = TrapAddressof();
30e24ddb60SLouis Dionne     assert(f() == 1);
31e24ddb60SLouis Dionne     return 0;
32e24ddb60SLouis Dionne }
33