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