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 Dionneint main(int, char**) { 29e24ddb60SLouis Dionne std::function<int()> f = TrapAddressof(); 30e24ddb60SLouis Dionne assert(f() == 1); 31e24ddb60SLouis Dionne return 0; 32e24ddb60SLouis Dionne } 33