From 2fd51946ee6fe72c1f8a1a8eab9c9e7fac6375f1 Mon Sep 17 00:00:00 2001 From: Chandler Carruth Date: Fri, 16 Dec 2011 09:36:16 +0000 Subject: [PATCH] Make GCC happy by using makeAraryRef instead of the implicit conversion. I have no idea why GCC can't cope with the implicit conversion and Clang can, or whose bug it is. Grr. llvm-svn: 146732 --- llvm/include/llvm/ADT/VariadicFunction.h | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/llvm/include/llvm/ADT/VariadicFunction.h b/llvm/include/llvm/ADT/VariadicFunction.h index 08c9697ffc16..00ae347dc730 100644 --- a/llvm/include/llvm/ADT/VariadicFunction.h +++ b/llvm/include/llvm/ADT/VariadicFunction.h @@ -114,7 +114,7 @@ class VariadicFunction { #define LLVM_DEFINE_OVERLOAD(N) \ ResultT operator()(LLVM_COMMA_JOIN ## N(const ArgT &A)) const { \ const ArgT *const Args[] = { LLVM_COMMA_JOIN ## N(&A) }; \ - return Func(Args); \ + return Func(makeArrayRef(Args)); \ } LLVM_DEFINE_OVERLOAD(1) LLVM_DEFINE_OVERLOAD(2) @@ -164,7 +164,7 @@ class VariadicFunction1 { #define LLVM_DEFINE_OVERLOAD(N) \ ResultT operator()(Param0T P0, LLVM_COMMA_JOIN ## N(const ArgT &A)) const { \ const ArgT *const Args[] = { LLVM_COMMA_JOIN ## N(&A) }; \ - return Func(P0, Args); \ + return Func(P0, makeArrayRef(Args)); \ } LLVM_DEFINE_OVERLOAD(1) LLVM_DEFINE_OVERLOAD(2) @@ -215,7 +215,7 @@ class VariadicFunction2 { ResultT operator()(Param0T P0, Param1T P1, \ LLVM_COMMA_JOIN ## N(const ArgT &A)) const { \ const ArgT *const Args[] = { LLVM_COMMA_JOIN ## N(&A) }; \ - return Func(P0, P1, Args); \ + return Func(P0, P1, makeAraryRef(Args)); \ } LLVM_DEFINE_OVERLOAD(1) LLVM_DEFINE_OVERLOAD(2) @@ -267,7 +267,7 @@ class VariadicFunction3 { ResultT operator()(Param0T P0, Param1T P1, Param2T P2, \ LLVM_COMMA_JOIN ## N(const ArgT &A)) const { \ const ArgT *const Args[] = { LLVM_COMMA_JOIN ## N(&A) }; \ - return Func(P0, P1, P2, Args); \ + return Func(P0, P1, P2, makeArrayRef(Args)); \ } LLVM_DEFINE_OVERLOAD(1) LLVM_DEFINE_OVERLOAD(2)