r198770 - clang-format: Don't hang forever when encountering a stray "}" in an @implementation block.

Daniel Jasper djasper at google.com
Wed Jan 8 08:08:04 PST 2014


Thank you!


On Wed, Jan 8, 2014 at 4:59 PM, Benjamin Kramer <benny.kra at googlemail.com>wrote:

> Author: d0k
> Date: Wed Jan  8 09:59:42 2014
> New Revision: 198770
>
> URL: http://llvm.org/viewvc/llvm-project?rev=198770&view=rev
> Log:
> clang-format: Don't hang forever when encountering a stray "}" in an
> @implementation block.
>
> PR18406.
>
> Modified:
>     cfe/trunk/lib/Format/UnwrappedLineParser.cpp
>     cfe/trunk/unittests/Format/FormatTest.cpp
>
> Modified: cfe/trunk/lib/Format/UnwrappedLineParser.cpp
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Format/UnwrappedLineParser.cpp?rev=198770&r1=198769&r2=198770&view=diff
>
> ==============================================================================
> --- cfe/trunk/lib/Format/UnwrappedLineParser.cpp (original)
> +++ cfe/trunk/lib/Format/UnwrappedLineParser.cpp Wed Jan  8 09:59:42 2014
> @@ -1255,6 +1255,10 @@ void UnwrappedLineParser::parseObjCUntil
>        parseBlock(/*MustBeDeclaration=*/false);
>        // In ObjC interfaces, nothing should be following the "}".
>        addUnwrappedLine();
> +    } else if (FormatTok->is(tok::r_brace)) {
> +      // Ignore stray "}". parseStructuralElement doesn't consume them.
> +      nextToken();
> +      addUnwrappedLine();
>      } else {
>        parseStructuralElement();
>      }
>
> Modified: cfe/trunk/unittests/Format/FormatTest.cpp
> URL:
> http://llvm.org/viewvc/llvm-project/cfe/trunk/unittests/Format/FormatTest.cpp?rev=198770&r1=198769&r2=198770&view=diff
>
> ==============================================================================
> --- cfe/trunk/unittests/Format/FormatTest.cpp (original)
> +++ cfe/trunk/unittests/Format/FormatTest.cpp Wed Jan  8 09:59:42 2014
> @@ -5596,6 +5596,10 @@ TEST_F(FormatTest, FormatObjCProtocol) {
>                 "    int *looooooooooooooooooooooooooooongNumber;\n"
>                 "@property(nonatomic, assign, readonly)\n"
>                 "    NSString *looooooooooooooooooooooooooooongName;");
> +
> +  verifyFormat("@implementation PR18406\n"
> +               "}\n"
> +               "@end");
>  }
>
>  TEST_F(FormatTest, FormatObjCMethodDeclarations) {
>
>
> _______________________________________________
> cfe-commits mailing list
> cfe-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/cfe-commits
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20140108/60c09493/attachment.html>


More information about the cfe-commits mailing list