diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2009-11-06 18:47:57 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2009-11-06 18:47:57 +0000 |
| commit | c2d71b531c63eeb9679af79f5437bbf150cb99ec (patch) | |
| tree | 903fe04e13706caa45eb3bebc132ddc622fa1564 | |
| parent | 8a6512961fb66fafa33953412c221e99a4ad1ae5 (diff) | |
| download | bcm5719-llvm-c2d71b531c63eeb9679af79f5437bbf150cb99ec.tar.gz bcm5719-llvm-c2d71b531c63eeb9679af79f5437bbf150cb99ec.zip | |
This patch fixes code gen. part of pr5333 (Conversion
using elipsis conversion).
llvm-svn: 86276
| -rw-r--r-- | clang/lib/CodeGen/CGCXX.cpp | 4 | ||||
| -rw-r--r-- | clang/test/CodeGenCXX/vararg-conversion-ctor.cpp | 24 |
2 files changed, 27 insertions, 1 deletions
diff --git a/clang/lib/CodeGen/CGCXX.cpp b/clang/lib/CodeGen/CGCXX.cpp index 0e6b5cb1434..cc6f13be1a6 100644 --- a/clang/lib/CodeGen/CGCXX.cpp +++ b/clang/lib/CodeGen/CGCXX.cpp @@ -649,8 +649,10 @@ void CodeGenModule::EmitCXXConstructor(const CXXConstructorDecl *D, llvm::Function * CodeGenModule::GetAddrOfCXXConstructor(const CXXConstructorDecl *D, CXXCtorType Type) { + const FunctionProtoType *FPT = D->getType()->getAs<FunctionProtoType>(); const llvm::FunctionType *FTy = - getTypes().GetFunctionType(getTypes().getFunctionInfo(D), false); + getTypes().GetFunctionType(getTypes().getFunctionInfo(D), + FPT->isVariadic()); const char *Name = getMangledCXXCtorName(D, Type); return cast<llvm::Function>( diff --git a/clang/test/CodeGenCXX/vararg-conversion-ctor.cpp b/clang/test/CodeGenCXX/vararg-conversion-ctor.cpp new file mode 100644 index 00000000000..d6110b76608 --- /dev/null +++ b/clang/test/CodeGenCXX/vararg-conversion-ctor.cpp @@ -0,0 +1,24 @@ +// RUN: clang-cc -triple x86_64-apple-darwin -std=c++0x -emit-llvm %s -o %t-64.ll && +// RUN: FileCheck -check-prefix LPLL64 --input-file=%t-64.ll %s && +// RUN: true + +extern "C" int printf(...); + +struct A { + A(...) { + printf("A::A(...)\n"); + } +}; + +A a(1.34); + +A b = 2.34; + +int main() +{ + A c[3]; +} + +// CHECK-LPLL64: call void (%struct.A*, ...) +// CHECK-LPLL64: call void (%struct.A*, ...) +// CHECK-LPLL64: call void (%struct.A*, ...) |

