/* Copyright (C) 2015 * swift Project Community / Contributors * * This file is part of swift project. It is subject to the license terms in the LICENSE file found in the top-level * directory of this distribution and at http://www.swift-project.org/license.html. No part of swift project, * including this file, may be copied, modified, propagated, or distributed except according to the terms * contained in the LICENSE file. */ //! \file #ifndef BLACKMISC_INVOKE_H #define BLACKMISC_INVOKE_H #include namespace BlackMisc { //! \cond PRIVATE namespace Private { // Our own version of C++17 std::invoke(). template ::value>> decltype(auto) invoke(F ptr, T &&object) { return std::forward(object).*ptr; } template ::value>> decltype(auto) invoke(F ptr, T &&object, Ts &&... args) { return (std::forward(object).*ptr)(std::forward(args)...); } template >::value>> decltype(auto) invoke(F &&func, Ts &&... args) { return std::forward(func)(std::forward(args)...); } // Like invoke() but ignores the first argument if callable is not a member function. For uniform calling of callables with slot semantics. template ::value>> decltype(auto) invokeSlot(F ptr, T *object, Ts &&... args) { return (object->*ptr)(std::forward(args)...); } template >::value>> decltype(auto) invokeSlot(F &&func, T *, Ts &&... args) { return std::forward(func)(std::forward(args)...); } } //! \endcond } #endif