From 534a15d05e0b6e1b44b6387003e1475150e848e8 Mon Sep 17 00:00:00 2001 From: Kitsune Ral Date: Sun, 29 Sep 2019 18:01:45 +0900 Subject: function_traits: drop unused pieces is_callable won't ever be needed because std::is_invokable is here; arg_number and returns() didn't find its users; and function_type has been just broken all along for member functions. --- lib/util.cpp | 38 ++------------------------------------ lib/util.h | 22 ++++------------------ 2 files changed, 6 insertions(+), 54 deletions(-) (limited to 'lib') diff --git a/lib/util.cpp b/lib/util.cpp index cc18d9ab..041a8aba 100644 --- a/lib/util.cpp +++ b/lib/util.cpp @@ -141,62 +141,28 @@ int f(); static_assert(std::is_same, int>::value, "Test fn_return_t<>"); -void f1(int); -static_assert(function_traits::arg_number == 1, - "Test fn_arg_number"); - -void f2(int, QString); -static_assert(std::is_same, QString>::value, +void f1(int, QString); +static_assert(std::is_same, QString>::value, "Test fn_arg_t<>"); -struct S { - int mf(); -}; -static_assert(is_callable_v, "Test member function"); -static_assert(returns(), - "Test returns<> with member function"); - struct Fo { int operator()(); }; -static_assert(is_callable_v, "Test is_callable<> with function object"); -static_assert(function_traits::arg_number == 0, "Test function object"); static_assert(std::is_same, int>::value, "Test return type of function object"); struct Fo1 { void operator()(int); }; -static_assert(function_traits::arg_number == 1, "Test function object 1"); -static_assert(is_callable_v, "Test is_callable<> with function object 1"); static_assert(std::is_same, int>(), "Test fn_arg_t defaulting to first argument"); #if (!defined(_MSC_VER) || _MSC_VER >= 1910) static auto l = [] { return 1; }; -static_assert(is_callable_v, "Test is_callable_v<> with lambda"); static_assert(std::is_same, int>::value, "Test fn_return_t<> with lambda"); #endif -template -struct fn_object { - static int smf(double) { return 0; } -}; -template <> -struct fn_object { - void operator()(QString); -}; -static_assert(is_callable_v>, "Test function object"); -static_assert(returns>(), - "Test returns<> with function object"); -static_assert(!is_callable_v>, "Test non-function object"); -// FIXME: These two don't work -// static_assert(is_callable_v::smf)>, -// "Test static member function"); -// static_assert(returns::smf)>(), -// "Test returns<> with static member function"); - template QString ft(T&&) { diff --git a/lib/util.h b/lib/util.h index 788ce5bc..4631570f 100644 --- a/lib/util.h +++ b/lib/util.h @@ -154,23 +154,19 @@ struct function_traits : public _impl::fn_traits {}; // Specialisation for a function template struct function_traits { - static constexpr auto is_callable = true; using return_type = ReturnT; using arg_types = std::tuple; - using function_type = std::function; - static constexpr auto arg_number = std::tuple_size::value; }; namespace _impl { template - struct fn_traits { - static constexpr auto is_callable = false; - }; + struct fn_traits; + // Specialisation for function objects with (non-overloaded) operator() + // (this includes non-generic lambdas) template struct fn_traits - : public fn_traits { - }; // A generic function object that has (non-overloaded) operator() + : public fn_traits {}; // Specialisation for a member function template @@ -190,16 +186,6 @@ template using fn_arg_t = std::tuple_element_t::arg_types>; -template -constexpr bool returns() -{ - return std::is_same, R>::value; -} - -// Poor-man's is_invokable -template -constexpr auto is_callable_v = function_traits::is_callable; - inline auto operator"" _ls(const char* s, std::size_t size) { return QLatin1String(s, int(size)); -- cgit v1.2.3