summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaCUDA/no-destructor-overload.cu
diff options
context:
space:
mode:
authorJustin Lebar <jlebar@google.com>2016-10-03 16:48:23 +0000
committerJustin Lebar <jlebar@google.com>2016-10-03 16:48:23 +0000
commite060feb7b1a98bcd083cf53ea3c05bc9eda432bb (patch)
tree763f4e6edf374e0a6a50c19abd244bf1179ca13a /clang/test/SemaCUDA/no-destructor-overload.cu
parentd27a21874b3d83bf0695eea90b6ba5aa3f600c88 (diff)
downloadbcm5719-llvm-e060feb7b1a98bcd083cf53ea3c05bc9eda432bb.tar.gz
bcm5719-llvm-e060feb7b1a98bcd083cf53ea3c05bc9eda432bb.zip
[CUDA] Disallow overloading destructors.
Summary: We'd attempted to allow this, but turns out we were doing a very bad job. :) Making this work properly would be a giant change in clang. For example, we'd need to make CXXRecordDecl::getDestructor() context-sensitive, because the destructor you end up with depends on where you're calling it from. For now (and hopefully for ever), just disallow overloading of destructors in CUDA. Reviewers: rsmith Subscribers: cfe-commits, tra Differential Revision: https://reviews.llvm.org/D24571 llvm-svn: 283120
Diffstat (limited to 'clang/test/SemaCUDA/no-destructor-overload.cu')
-rw-r--r--clang/test/SemaCUDA/no-destructor-overload.cu33
1 files changed, 33 insertions, 0 deletions
diff --git a/clang/test/SemaCUDA/no-destructor-overload.cu b/clang/test/SemaCUDA/no-destructor-overload.cu
new file mode 100644
index 00000000000..aa6971ee8ca
--- /dev/null
+++ b/clang/test/SemaCUDA/no-destructor-overload.cu
@@ -0,0 +1,33 @@
+// RUN: %clang_cc1 -fsyntax-only -verify %s
+// RUN: %clang_cc1 -fcuda-is-device -fsyntax-only -verify %s
+
+#include "Inputs/cuda.h"
+
+// We don't allow destructors to be overloaded. Making this work would be a
+// giant change to clang, and the use cases seem quite limited.
+
+struct A {
+ ~A() {} // expected-note {{previous declaration is here}}
+ __device__ ~A() {} // expected-error {{destructor cannot be redeclared}}
+};
+
+struct B {
+ __host__ ~B() {} // expected-note {{previous declaration is here}}
+ __host__ __device__ ~B() {} // expected-error {{destructor cannot be redeclared}}
+};
+
+struct C {
+ __host__ __device__ ~C() {} // expected-note {{previous declaration is here}}
+ __host__ ~C() {} // expected-error {{destructor cannot be redeclared}}
+};
+
+struct D {
+ __device__ ~D() {} // expected-note {{previous declaration is here}}
+ __host__ __device__ ~D() {} // expected-error {{destructor cannot be redeclared}}
+};
+
+struct E {
+ __host__ __device__ ~E() {} // expected-note {{previous declaration is here}}
+ __device__ ~E() {} // expected-error {{destructor cannot be redeclared}}
+};
+
OpenPOWER on IntegriCloud