diff options
| author | Benjamin Kramer <benny.kra@googlemail.com> | 2013-09-09 15:08:57 +0000 |
|---|---|---|
| committer | Benjamin Kramer <benny.kra@googlemail.com> | 2013-09-09 15:08:57 +0000 |
| commit | 7037021e78454ff191cd8c2bf796745fba844c2f (patch) | |
| tree | af0f9b46239b89277fe99c0967449eef6ad9537d /clang/lib | |
| parent | 60509af49add1fedf59d0e117c90c273b70fdaed (diff) | |
| download | bcm5719-llvm-7037021e78454ff191cd8c2bf796745fba844c2f.tar.gz bcm5719-llvm-7037021e78454ff191cd8c2bf796745fba844c2f.zip | |
Sema: Don't crash on visibility attributes with an identifier argument.
PR17105.
llvm-svn: 190312
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Sema/SemaDeclAttr.cpp | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/clang/lib/Sema/SemaDeclAttr.cpp b/clang/lib/Sema/SemaDeclAttr.cpp index 78b963c16ff..0a6cee900b4 100644 --- a/clang/lib/Sema/SemaDeclAttr.cpp +++ b/clang/lib/Sema/SemaDeclAttr.cpp @@ -2438,9 +2438,10 @@ static void handleVisibilityAttr(Sema &S, Decl *D, const AttributeList &Attr, if (!checkAttributeNumArgs(S, Attr, 1)) return; - Expr *Arg = Attr.getArgAsExpr(0); - Arg = Arg->IgnoreParenCasts(); - StringLiteral *Str = dyn_cast<StringLiteral>(Arg); + // Check that the argument is a string literal. + StringLiteral *Str = 0; + if (Attr.isArgExpr(0)) + Str = dyn_cast<StringLiteral>(Attr.getArgAsExpr(0)->IgnoreParenCasts()); if (!Str || !Str->isAscii()) { S.Diag(Attr.getLoc(), diag::err_attribute_argument_type) |

