diff options
author | Dmitri Gribenko <gribozavr@gmail.com> | 2012-06-28 01:38:21 +0000 |
---|---|---|
committer | Dmitri Gribenko <gribozavr@gmail.com> | 2012-06-28 01:38:21 +0000 |
commit | d558b5238df74ef3cb76d7125375a5c28fe0eaa9 (patch) | |
tree | 5ee6efdb0e2758b9bb98523670935adfa6267074 | |
parent | da970d2fe086ed44198e1edd5d7d59ff19e747fe (diff) |
Cleanup \brief comment. Since it is a single paragraph, no need to save newlines there.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@159325 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/AST/CommentBriefParser.cpp | 31 | ||||
-rw-r--r-- | test/Index/annotate-comments-unterminated.c | 4 | ||||
-rw-r--r-- | test/Index/annotate-comments.cpp | 6 |
3 files changed, 35 insertions, 6 deletions
diff --git a/lib/AST/CommentBriefParser.cpp b/lib/AST/CommentBriefParser.cpp index f647309246..4040a99924 100644 --- a/lib/AST/CommentBriefParser.cpp +++ b/lib/AST/CommentBriefParser.cpp @@ -12,6 +12,34 @@ namespace clang { namespace comments { +namespace { +/// Convert all whitespace into spaces, remove leading and trailing spaces, +/// compress multiple spaces into one. +void cleanupBrief(std::string &S) { + bool PrevWasSpace = true; + std::string::iterator O = S.begin(); + for (std::string::iterator I = S.begin(), E = S.end(); + I != E; ++I) { + const char C = *I; + if (C == ' ' || C == '\n' || C == '\r' || + C == '\t' || C == '\v' || C == '\f') { + if (!PrevWasSpace) { + *O++ = ' '; + PrevWasSpace = true; + } + continue; + } else { + *O++ = C; + PrevWasSpace = false; + } + } + if (O != S.begin() && *(O - 1) == ' ') + --O; + + S.resize(O - S.begin()); +} +} // unnamed namespace + std::string BriefParser::Parse() { std::string Paragraph; bool InFirstParagraph = true; @@ -47,7 +75,7 @@ std::string BriefParser::Parse() { if (Tok.is(tok::newline)) { if (InFirstParagraph || InBrief) - Paragraph += '\n'; + Paragraph += ' '; ConsumeToken(); if (Tok.is(tok::newline)) { @@ -66,6 +94,7 @@ std::string BriefParser::Parse() { ConsumeToken(); } + cleanupBrief(Paragraph); return Paragraph; } diff --git a/test/Index/annotate-comments-unterminated.c b/test/Index/annotate-comments-unterminated.c index d72822a093..6bba911aac 100644 --- a/test/Index/annotate-comments-unterminated.c +++ b/test/Index/annotate-comments-unterminated.c @@ -1,8 +1,8 @@ // RUN: c-index-test -test-load-source all %s | FileCheck %s // RUN: %clang_cc1 -fsyntax-only %s 2>&1 | FileCheck -check-prefix=ERR %s -// CHECK: annotate-comments-unterminated.c:9:5: VarDecl=x:{{.*}} RawComment=[/** Aaa. */]{{.*}} BriefComment=[ Aaa. \n] -// CHECK: annotate-comments-unterminated.c:11:5: VarDecl=y:{{.*}} RawComment=[/**< Bbb. */]{{.*}} BriefComment=[ Bbb. \n] +// CHECK: annotate-comments-unterminated.c:9:5: VarDecl=x:{{.*}} RawComment=[/** Aaa. */]{{.*}} BriefComment=[Aaa.] +// CHECK: annotate-comments-unterminated.c:11:5: VarDecl=y:{{.*}} RawComment=[/**< Bbb. */]{{.*}} BriefComment=[Bbb.] // CHECK-ERR: error: unterminated /** Aaa. */ diff --git a/test/Index/annotate-comments.cpp b/test/Index/annotate-comments.cpp index 59ffa88348..aa68defe95 100644 --- a/test/Index/annotate-comments.cpp +++ b/test/Index/annotate-comments.cpp @@ -268,7 +268,7 @@ void isdoxy47(int); // CHECK: annotate-comments.cpp:163:7: FieldDecl=isdoxy42:{{.*}} isdoxy42 IS_DOXYGEN_SINGLE // CHECK: annotate-comments.cpp:176:6: FunctionDecl=isdoxy43:{{.*}} IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END -// CHECK: annotate-comments.cpp:185:6: FunctionDecl=isdoxy44:{{.*}} BriefComment=[ IS_DOXYGEN_START Aaa bbb\n ccc.\n] -// CHECK: annotate-comments.cpp:195:6: FunctionDecl=isdoxy45:{{.*}} BriefComment=[\n Ddd eee.\n Fff.\n] -// CHECK: annotate-comments.cpp:204:6: FunctionDecl=isdoxy47:{{.*}} BriefComment=[ IS_DOXYGEN_START Aaa bbb\n ] +// CHECK: annotate-comments.cpp:185:6: FunctionDecl=isdoxy44:{{.*}} BriefComment=[IS_DOXYGEN_START Aaa bbb ccc.] +// CHECK: annotate-comments.cpp:195:6: FunctionDecl=isdoxy45:{{.*}} BriefComment=[Ddd eee. Fff.] +// CHECK: annotate-comments.cpp:204:6: FunctionDecl=isdoxy47:{{.*}} BriefComment=[IS_DOXYGEN_START Aaa bbb] |