diff options
author | Anders Carlsson <andersca@mac.com> | 2009-01-13 17:00:51 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-01-13 17:00:51 +0000 |
commit | 53859912e4b5c4493e28c9ead8d634fdaac6adaf (patch) | |
tree | c833af9599a4269e97878ca0aeac08465176fe37 | |
parent | 9b9ca01ff3136a7539dc08a4c4e1a3dd8c8d3a7d (diff) |
Use the unqualified type for GCCs struct/union cast extension
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@62170 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Sema/SemaExpr.cpp | 4 | ||||
-rw-r--r-- | test/Sema/struct-cast.c | 14 |
2 files changed, 16 insertions, 2 deletions
diff --git a/lib/Sema/SemaExpr.cpp b/lib/Sema/SemaExpr.cpp index 2721bb8dc6..41881a2e5b 100644 --- a/lib/Sema/SemaExpr.cpp +++ b/lib/Sema/SemaExpr.cpp @@ -1912,8 +1912,8 @@ bool Sema::CheckCastTypes(SourceRange TyR, QualType castType, Expr *&castExpr) { // We can't check any more until template instantiation time. } else if (!castType->isScalarType() && !castType->isVectorType()) { // GCC struct/union extension: allow cast to self. - if (Context.getCanonicalType(castType) != - Context.getCanonicalType(castExpr->getType()) || + if (Context.getCanonicalType(castType).getUnqualifiedType() != + Context.getCanonicalType(castExpr->getType().getUnqualifiedType()) || (!castType->isStructureType() && !castType->isUnionType())) { // Reject any other conversions to non-scalar types. return Diag(TyR.getBegin(), diag::err_typecheck_cond_expect_scalar) diff --git a/test/Sema/struct-cast.c b/test/Sema/struct-cast.c new file mode 100644 index 0000000000..734be804e6 --- /dev/null +++ b/test/Sema/struct-cast.c @@ -0,0 +1,14 @@ +// RUN: clang -fsyntax-only %s -verify + +struct S { + int one; + int two; +}; + +struct S const foo(void); + +struct S tmp; + +void priv_sock_init() { + tmp = (struct S)foo(); +} |