[cfe-commits] r161020 - in /cfe/trunk: lib/Sema/SemaType.cpp test/CodeGenCXX/pr13396.cpp
Rafael Espindola
rafael.espindola at gmail.com
Mon Jul 30 18:54:04 PDT 2012
Author: rafael
Date: Mon Jul 30 20:54:04 2012
New Revision: 161020
URL: http://llvm.org/viewvc/llvm-project?rev=161020&view=rev
Log:
Attributes preceding a function declaration are first applied to the return
type and then propagated to the function. This was failing for destructors,
constructors and constructors templates since they don't have a return type.
Fix that by directly calling processTypeAttrs on the dummy type we use as the
return type in these cases.
Added:
cfe/trunk/test/CodeGenCXX/pr13396.cpp
Modified:
cfe/trunk/lib/Sema/SemaType.cpp
Modified: cfe/trunk/lib/Sema/SemaType.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaType.cpp?rev=161020&r1=161019&r2=161020&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaType.cpp (original)
+++ cfe/trunk/lib/Sema/SemaType.cpp Mon Jul 30 20:54:04 2012
@@ -1812,6 +1812,8 @@
// Constructors and destructors don't have return types. Use
// "void" instead.
T = SemaRef.Context.VoidTy;
+ if (AttributeList *attrs = D.getDeclSpec().getAttributes().getList())
+ processTypeAttrs(state, T, true, attrs);
break;
case UnqualifiedId::IK_ConversionFunctionId:
Added: cfe/trunk/test/CodeGenCXX/pr13396.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGenCXX/pr13396.cpp?rev=161020&view=auto
==============================================================================
--- cfe/trunk/test/CodeGenCXX/pr13396.cpp (added)
+++ cfe/trunk/test/CodeGenCXX/pr13396.cpp Mon Jul 30 20:54:04 2012
@@ -0,0 +1,26 @@
+// RUN: %clang_cc1 %s -emit-llvm -o - | FileCheck %s
+struct foo {
+ template<typename T>
+ __attribute__ ((regparm (3))) foo(T x) {}
+ __attribute__ ((regparm (3))) foo();
+ __attribute__ ((regparm (3))) ~foo();
+};
+
+foo::foo() {
+ // CHECK: define void @_ZN3fooC1Ev(%struct.foo* inreg %this)
+ // CHECK: define void @_ZN3fooC2Ev(%struct.foo* inreg %this)
+}
+
+foo::~foo() {
+ // CHECK: define void @_ZN3fooD1Ev(%struct.foo* inreg %this)
+ // CHECK: define void @_ZN3fooD2Ev(%struct.foo* inreg %this)
+}
+
+void dummy() {
+ // FIXME: how can we explicitly instantiate a template constructor? Gcc and
+ // older clangs accept:
+ // template foo::foo(int x);
+ foo x(10);
+ // CHECK: define linkonce_odr void @_ZN3fooC1IiEET_(%struct.foo* inreg %this, i32 inreg %x)
+ // CHECK: define linkonce_odr void @_ZN3fooC2IiEET_(%struct.foo* inreg %this, i32 inreg %x)
+}
More information about the cfe-commits
mailing list