summaryrefslogtreecommitdiffstats
path: root/clang/test/Sema/vla-2.c
diff options
context:
space:
mode:
authorEli Friedman <eli.friedman@gmail.com>2012-01-21 01:01:51 +0000
committerEli Friedman <eli.friedman@gmail.com>2012-01-21 01:01:51 +0000
commite0afc98742422e99f7ed4c5f82812ab64781d7e7 (patch)
tree814bdbd4523e47b3b5c92378658f47d9876a3af5 /clang/test/Sema/vla-2.c
parent8e3bb315d8721211474fb7759002acb1c190317e (diff)
downloadbcm5719-llvm-e0afc98742422e99f7ed4c5f82812ab64781d7e7.tar.gz
bcm5719-llvm-e0afc98742422e99f7ed4c5f82812ab64781d7e7.zip
Make clang's AST model sizeof and typeof with potentially-evaluated operands correctly, similar to what we already do with typeid.
llvm-svn: 148610
Diffstat (limited to 'clang/test/Sema/vla-2.c')
-rw-r--r--clang/test/Sema/vla-2.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/clang/test/Sema/vla-2.c b/clang/test/Sema/vla-2.c
new file mode 100644
index 00000000000..819cab91afc
--- /dev/null
+++ b/clang/test/Sema/vla-2.c
@@ -0,0 +1,17 @@
+// RUN: %clang_cc1 %s -verify -fsyntax-only -pedantic
+// Check that we don't crash trying to emit warnings in a potentially-evaluated
+// sizeof or typeof. (This test needs to be in a separate file because we use
+// a different codepath when we have already emitted an error.)
+
+int PotentiallyEvaluatedSizeofWarn(int n) {
+ return (int)sizeof *(0 << 32,(int(*)[n])0); // expected-warning {{expression result unused}} expected-warning {{shift count >= width of type}}
+}
+
+void PotentiallyEvaluatedTypeofWarn(int n) {
+ __typeof(*(0 << 32,(int(*)[n])0)) x; // expected-warning {{expression result unused}} expected-warning {{shift count >= width of type}}
+ (void)x;
+}
+
+void PotentiallyEvaluatedArrayBoundWarn(int n) {
+ (void)*(int(*)[(0 << 32,n)])0; // FIXME: We should warn here.
+}
OpenPOWER on IntegriCloud