diff options
author | Benjamin Kramer <benny.kra@googlemail.com> | 2013-12-01 15:09:32 +0000 |
---|---|---|
committer | Benjamin Kramer <benny.kra@googlemail.com> | 2013-12-01 15:09:32 +0000 |
commit | 2dece5747a0f7bd711a5d8fa93b613351f7b6e07 (patch) | |
tree | 327d6bb547f85217a38a073966d286bb34690baf | |
parent | 45479dcf49845d2faace66c12921be1412721265 (diff) | |
download | bcm5719-llvm-2dece5747a0f7bd711a5d8fa93b613351f7b6e07.tar.gz bcm5719-llvm-2dece5747a0f7bd711a5d8fa93b613351f7b6e07.zip |
CommentLexer: When proceeding with a typo corrected name don't clobber the token.
This would crash if the token is used in another diagnostic. PR18051.
llvm-svn: 196048
-rw-r--r-- | clang/lib/AST/CommentLexer.cpp | 11 | ||||
-rw-r--r-- | clang/test/Sema/warn-documentation-fixits.cpp | 6 |
2 files changed, 12 insertions, 5 deletions
diff --git a/clang/lib/AST/CommentLexer.cpp b/clang/lib/AST/CommentLexer.cpp index 475532d9a99..01ed3ce80a6 100644 --- a/clang/lib/AST/CommentLexer.cpp +++ b/clang/lib/AST/CommentLexer.cpp @@ -353,16 +353,17 @@ void Lexer::lexCommentText(Token &T) { const CommandInfo *Info = Traits.getCommandInfoOrNULL(CommandName); if (!Info) { - formTokenWithChars(T, TokenPtr, tok::unknown_command); - T.setUnknownCommandName(CommandName); if ((Info = Traits.getTypoCorrectCommandInfo(CommandName))) { StringRef CorrectedName = Info->Name; - SourceRange CommandRange(T.getLocation().getLocWithOffset(1), - T.getEndLocation()); - Diag(T.getLocation(), diag::warn_correct_comment_command_name) + SourceLocation Loc = getSourceLocation(BufferPtr); + SourceRange CommandRange(Loc.getLocWithOffset(1), + getSourceLocation(TokenPtr)); + Diag(Loc, diag::warn_correct_comment_command_name) << CommandName << CorrectedName << FixItHint::CreateReplacement(CommandRange, CorrectedName); } else { + formTokenWithChars(T, TokenPtr, tok::unknown_command); + T.setUnknownCommandName(CommandName); Diag(T.getLocation(), diag::warn_unknown_comment_command_name); return; } diff --git a/clang/test/Sema/warn-documentation-fixits.cpp b/clang/test/Sema/warn-documentation-fixits.cpp index a5a477f66d6..675d86c366d 100644 --- a/clang/test/Sema/warn-documentation-fixits.cpp +++ b/clang/test/Sema/warn-documentation-fixits.cpp @@ -70,6 +70,11 @@ int gorf(); /// \t bbb IS_DOXYGEN_END int Bar(); +// expected-warning@+2 {{unknown command tag name 'encode'; did you mean 'endcode'?}} +// expected-warning@+1 {{'\endcode' command does not terminate a verbatim text block}} +/// \encode PR18051 +int PR18051(); + // CHECK: fix-it:"{{.*}}":{5:12-5:22}:"a" // CHECK: fix-it:"{{.*}}":{9:12-9:15}:"aaa" // CHECK: fix-it:"{{.*}}":{13:13-13:23}:"T" @@ -83,3 +88,4 @@ int Bar(); // CHECK: fix-it:"{{.*}}":{58:30-58:30}:" MY_ATTR_DEPRECATED" // CHECK: fix-it:"{{.*}}":{63:6-63:11}:"return" // CHECK: fix-it:"{{.*}}":{67:6-67:11}:"foobar" +// CHECK: fix-it:"{{.*}}":{75:6-75:12}:"endcode" |