summaryrefslogtreecommitdiffstats
path: root/clang/test/Sema/array-init.c
diff options
context:
space:
mode:
authorSteve Naroff <snaroff@apple.com>2007-10-18 03:27:23 +0000
committerSteve Naroff <snaroff@apple.com>2007-10-18 03:27:23 +0000
commit8569d7734906b2e3823300cc306c44720f946135 (patch)
tree4390445f7bda1c6112e44256b15012dbf0314b50 /clang/test/Sema/array-init.c
parent94977674587dabd56481c438bd4e934a43e8e80a (diff)
downloadbcm5719-llvm-8569d7734906b2e3823300cc306c44720f946135.tar.gz
bcm5719-llvm-8569d7734906b2e3823300cc306c44720f946135.zip
Fix the following bug...
unsigned char asso_values[] = { 34 }; int legal2() { return asso_values[0]; } The code that creates the new constant array type was operating on the original type. As a result, the constant type being generated was "unsigned char [1][]" (which is wrong). The fix is to operate on the element type - in this case, the correct type is "unsigned char [1]" I added this case to array-init.c, which clearly didn't catch this bogosity... llvm-svn: 43112
Diffstat (limited to 'clang/test/Sema/array-init.c')
-rw-r--r--clang/test/Sema/array-init.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/clang/test/Sema/array-init.c b/clang/test/Sema/array-init.c
index 510a7792d13..5b22681d1b9 100644
--- a/clang/test/Sema/array-init.c
+++ b/clang/test/Sema/array-init.c
@@ -103,6 +103,11 @@ void legal() {
};
}
+unsigned char asso_values[] = { 34 };
+int legal2() {
+ return asso_values[0];
+}
+
void illegal() {
short q2[4][][2] = { // expected-error{{array has incomplete element type 'short [][2]'}}
{ 1, 0, 0, 0, 0, 0 },
OpenPOWER on IntegriCloud