[PATCH] D134042: [clang-format] Fix alignment in #else preprocessor blocks
Mitchell via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Fri Sep 16 06:43:01 PDT 2022
mitchell-stellar created this revision.
mitchell-stellar added reviewers: HazardyKnusperkeks, curdeius, MyDeveloperDay.
mitchell-stellar added a project: clang-format.
Herald added a project: All.
mitchell-stellar requested review of this revision.
Herald added a project: clang.
Fixes https://github.com/llvm/llvm-project/issues/36070
clang-format makes multiple passes when #if/#else preprocessor blocks are found. It will make one pass for normal code and code in the #if block, and then it will make another pass for just the code in #else blocks. This often results in invalid alignment inside the else blocks because they do not have any scope or indentAndNestingLevel context from their surrounding tokens/lines.
This patch remedies that by caching any initial indentAndNestingLevel from a second pass and not breaking/returning early when a scope change is detected.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D134042
Files:
clang/lib/Format/WhitespaceManager.cpp
clang/unittests/Format/FormatTest.cpp
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D134042.460716.patch
Type: text/x-patch
Size: 7404 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20220916/fd45b5fe/attachment-0001.bin>
More information about the cfe-commits
mailing list