diff options
author | Steve Naroff <snaroff@apple.com> | 2007-10-18 03:27:23 +0000 |
---|---|---|
committer | Steve Naroff <snaroff@apple.com> | 2007-10-18 03:27:23 +0000 |
commit | 8569d7734906b2e3823300cc306c44720f946135 (patch) | |
tree | 4390445f7bda1c6112e44256b15012dbf0314b50 /clang/test/Sema/array-init.c | |
parent | 94977674587dabd56481c438bd4e934a43e8e80a (diff) | |
download | bcm5719-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.c | 5 |
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 }, |