From cc97c6eaa0fa39a5107f5a4da7782692347d6d79 Mon Sep 17 00:00:00 2001 From: Christopher Dykes Date: Mon, 21 Nov 2016 15:40:54 -0800 Subject: [PATCH] Work around an MSVC expression SFINAE bug in DynamicParser Summary: The good news is that it's cleaner than it was to start with. Reviewed By: yfeldblum Differential Revision: D4215323 fbshipit-source-id: 6758092f1e76f60b360753026bb7716737a51304 --- folly/experimental/DynamicParser-inl.h | 24 ++++++++++-------------- 1 file changed, 10 insertions(+), 14 deletions(-) diff --git a/folly/experimental/DynamicParser-inl.h b/folly/experimental/DynamicParser-inl.h index f3dc0c35..df390b74 100644 --- a/folly/experimental/DynamicParser-inl.h +++ b/folly/experimental/DynamicParser-inl.h @@ -77,22 +77,18 @@ using ArgumentTypes = // extended. The comparison deliberately strips cv-qualifieers and // reference, leaving that choice up to the caller. template -constexpr bool hasArgumentTypes() { - using HasArgumentTypes = typename boost::mpl::template equal< - typename boost::mpl::template transform< - typename boost::mpl::template transform< - ArgumentTypes, - typename std::template remove_reference - >::type, - typename std::template remove_cv - >::type, - boost::mpl::vector - >::type; - return HasArgumentTypes::value; -} +struct HasArgumentTypes + : boost::mpl::template equal< + typename boost::mpl::template transform< + typename boost::mpl::template transform< + ArgumentTypes, + typename std::template remove_reference>:: + type, + typename std::template remove_cv>::type, + boost::mpl::vector>::type {}; template using EnableForArgTypes = - typename std::enable_if(), void>::type; + typename std::enable_if::value, void>::type; // No arguments template EnableForArgTypes -- 2.34.1