annotate clang/lib/Format/WhitespaceManager.h @ 223:5f17cb93ff66 llvm-original

LLVM13 (2021/7/18)
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sun, 18 Jul 2021 22:43:00 +0900
parents 0572611fdcc8
children c4bab56944e8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 //===--- WhitespaceManager.h - Format C++ code ------------------*- C++ -*-===//
anatofuz
parents:
diff changeset
2 //
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
anatofuz
parents:
diff changeset
6 //
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
8 ///
anatofuz
parents:
diff changeset
9 /// \file
anatofuz
parents:
diff changeset
10 /// WhitespaceManager class manages whitespace around tokens and their
anatofuz
parents:
diff changeset
11 /// replacements.
anatofuz
parents:
diff changeset
12 ///
anatofuz
parents:
diff changeset
13 //===----------------------------------------------------------------------===//
anatofuz
parents:
diff changeset
14
anatofuz
parents:
diff changeset
15 #ifndef LLVM_CLANG_LIB_FORMAT_WHITESPACEMANAGER_H
anatofuz
parents:
diff changeset
16 #define LLVM_CLANG_LIB_FORMAT_WHITESPACEMANAGER_H
anatofuz
parents:
diff changeset
17
anatofuz
parents:
diff changeset
18 #include "TokenAnnotator.h"
anatofuz
parents:
diff changeset
19 #include "clang/Basic/SourceManager.h"
anatofuz
parents:
diff changeset
20 #include "clang/Format/Format.h"
223
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
21 #include "llvm/ADT/SmallVector.h"
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
22 #include <algorithm>
150
anatofuz
parents:
diff changeset
23 #include <string>
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
24 #include <tuple>
150
anatofuz
parents:
diff changeset
25
anatofuz
parents:
diff changeset
26 namespace clang {
anatofuz
parents:
diff changeset
27 namespace format {
anatofuz
parents:
diff changeset
28
anatofuz
parents:
diff changeset
29 /// Manages the whitespaces around tokens and their replacements.
anatofuz
parents:
diff changeset
30 ///
anatofuz
parents:
diff changeset
31 /// This includes special handling for certain constructs, e.g. the alignment of
anatofuz
parents:
diff changeset
32 /// trailing line comments.
anatofuz
parents:
diff changeset
33 ///
anatofuz
parents:
diff changeset
34 /// To guarantee correctness of alignment operations, the \c WhitespaceManager
anatofuz
parents:
diff changeset
35 /// must be informed about every token in the source file; for each token, there
anatofuz
parents:
diff changeset
36 /// must be exactly one call to either \c replaceWhitespace or
anatofuz
parents:
diff changeset
37 /// \c addUntouchableToken.
anatofuz
parents:
diff changeset
38 ///
anatofuz
parents:
diff changeset
39 /// There may be multiple calls to \c breakToken for a given token.
anatofuz
parents:
diff changeset
40 class WhitespaceManager {
anatofuz
parents:
diff changeset
41 public:
anatofuz
parents:
diff changeset
42 WhitespaceManager(const SourceManager &SourceMgr, const FormatStyle &Style,
anatofuz
parents:
diff changeset
43 bool UseCRLF)
anatofuz
parents:
diff changeset
44 : SourceMgr(SourceMgr), Style(Style), UseCRLF(UseCRLF) {}
anatofuz
parents:
diff changeset
45
anatofuz
parents:
diff changeset
46 bool useCRLF() const { return UseCRLF; }
anatofuz
parents:
diff changeset
47
anatofuz
parents:
diff changeset
48 /// Replaces the whitespace in front of \p Tok. Only call once for
anatofuz
parents:
diff changeset
49 /// each \c AnnotatedToken.
anatofuz
parents:
diff changeset
50 ///
anatofuz
parents:
diff changeset
51 /// \p StartOfTokenColumn is the column at which the token will start after
anatofuz
parents:
diff changeset
52 /// this replacement. It is needed for determining how \p Spaces is turned
anatofuz
parents:
diff changeset
53 /// into tabs and spaces for some format styles.
anatofuz
parents:
diff changeset
54 void replaceWhitespace(FormatToken &Tok, unsigned Newlines, unsigned Spaces,
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
55 unsigned StartOfTokenColumn, bool isAligned = false,
150
anatofuz
parents:
diff changeset
56 bool InPPDirective = false);
anatofuz
parents:
diff changeset
57
anatofuz
parents:
diff changeset
58 /// Adds information about an unchangeable token's whitespace.
anatofuz
parents:
diff changeset
59 ///
anatofuz
parents:
diff changeset
60 /// Needs to be called for every token for which \c replaceWhitespace
anatofuz
parents:
diff changeset
61 /// was not called.
anatofuz
parents:
diff changeset
62 void addUntouchableToken(const FormatToken &Tok, bool InPPDirective);
anatofuz
parents:
diff changeset
63
anatofuz
parents:
diff changeset
64 llvm::Error addReplacement(const tooling::Replacement &Replacement);
anatofuz
parents:
diff changeset
65
anatofuz
parents:
diff changeset
66 /// Inserts or replaces whitespace in the middle of a token.
anatofuz
parents:
diff changeset
67 ///
anatofuz
parents:
diff changeset
68 /// Inserts \p PreviousPostfix, \p Newlines, \p Spaces and \p CurrentPrefix
anatofuz
parents:
diff changeset
69 /// (in this order) at \p Offset inside \p Tok, replacing \p ReplaceChars
anatofuz
parents:
diff changeset
70 /// characters.
anatofuz
parents:
diff changeset
71 ///
anatofuz
parents:
diff changeset
72 /// Note: \p Spaces can be negative to retain information about initial
anatofuz
parents:
diff changeset
73 /// relative column offset between a line of a block comment and the start of
anatofuz
parents:
diff changeset
74 /// the comment. This negative offset may be compensated by trailing comment
anatofuz
parents:
diff changeset
75 /// alignment here. In all other cases negative \p Spaces will be truncated to
anatofuz
parents:
diff changeset
76 /// 0.
anatofuz
parents:
diff changeset
77 ///
anatofuz
parents:
diff changeset
78 /// When \p InPPDirective is true, escaped newlines are inserted. \p Spaces is
anatofuz
parents:
diff changeset
79 /// used to align backslashes correctly.
anatofuz
parents:
diff changeset
80 void replaceWhitespaceInToken(const FormatToken &Tok, unsigned Offset,
anatofuz
parents:
diff changeset
81 unsigned ReplaceChars,
anatofuz
parents:
diff changeset
82 StringRef PreviousPostfix,
anatofuz
parents:
diff changeset
83 StringRef CurrentPrefix, bool InPPDirective,
anatofuz
parents:
diff changeset
84 unsigned Newlines, int Spaces);
anatofuz
parents:
diff changeset
85
anatofuz
parents:
diff changeset
86 /// Returns all the \c Replacements created during formatting.
anatofuz
parents:
diff changeset
87 const tooling::Replacements &generateReplacements();
anatofuz
parents:
diff changeset
88
anatofuz
parents:
diff changeset
89 /// Represents a change before a token, a break inside a token,
anatofuz
parents:
diff changeset
90 /// or the layout of an unchanged token (or whitespace within).
anatofuz
parents:
diff changeset
91 struct Change {
anatofuz
parents:
diff changeset
92 /// Functor to sort changes in original source order.
anatofuz
parents:
diff changeset
93 class IsBeforeInFile {
anatofuz
parents:
diff changeset
94 public:
anatofuz
parents:
diff changeset
95 IsBeforeInFile(const SourceManager &SourceMgr) : SourceMgr(SourceMgr) {}
anatofuz
parents:
diff changeset
96 bool operator()(const Change &C1, const Change &C2) const;
anatofuz
parents:
diff changeset
97
anatofuz
parents:
diff changeset
98 private:
anatofuz
parents:
diff changeset
99 const SourceManager &SourceMgr;
anatofuz
parents:
diff changeset
100 };
anatofuz
parents:
diff changeset
101
anatofuz
parents:
diff changeset
102 /// Creates a \c Change.
anatofuz
parents:
diff changeset
103 ///
anatofuz
parents:
diff changeset
104 /// The generated \c Change will replace the characters at
anatofuz
parents:
diff changeset
105 /// \p OriginalWhitespaceRange with a concatenation of
anatofuz
parents:
diff changeset
106 /// \p PreviousLinePostfix, \p NewlinesBefore line breaks, \p Spaces spaces
anatofuz
parents:
diff changeset
107 /// and \p CurrentLinePrefix.
anatofuz
parents:
diff changeset
108 ///
anatofuz
parents:
diff changeset
109 /// \p StartOfTokenColumn and \p InPPDirective will be used to lay out
anatofuz
parents:
diff changeset
110 /// trailing comments and escaped newlines.
anatofuz
parents:
diff changeset
111 Change(const FormatToken &Tok, bool CreateReplacement,
anatofuz
parents:
diff changeset
112 SourceRange OriginalWhitespaceRange, int Spaces,
anatofuz
parents:
diff changeset
113 unsigned StartOfTokenColumn, unsigned NewlinesBefore,
anatofuz
parents:
diff changeset
114 StringRef PreviousLinePostfix, StringRef CurrentLinePrefix,
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
115 bool IsAligned, bool ContinuesPPDirective, bool IsInsideToken);
150
anatofuz
parents:
diff changeset
116
anatofuz
parents:
diff changeset
117 // The kind of the token whose whitespace this change replaces, or in which
anatofuz
parents:
diff changeset
118 // this change inserts whitespace.
anatofuz
parents:
diff changeset
119 // FIXME: Currently this is not set correctly for breaks inside comments, as
anatofuz
parents:
diff changeset
120 // the \c BreakableToken is still doing its own alignment.
anatofuz
parents:
diff changeset
121 const FormatToken *Tok;
anatofuz
parents:
diff changeset
122
anatofuz
parents:
diff changeset
123 bool CreateReplacement;
anatofuz
parents:
diff changeset
124 // Changes might be in the middle of a token, so we cannot just keep the
anatofuz
parents:
diff changeset
125 // FormatToken around to query its information.
anatofuz
parents:
diff changeset
126 SourceRange OriginalWhitespaceRange;
anatofuz
parents:
diff changeset
127 unsigned StartOfTokenColumn;
anatofuz
parents:
diff changeset
128 unsigned NewlinesBefore;
anatofuz
parents:
diff changeset
129 std::string PreviousLinePostfix;
anatofuz
parents:
diff changeset
130 std::string CurrentLinePrefix;
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
131 bool IsAligned;
150
anatofuz
parents:
diff changeset
132 bool ContinuesPPDirective;
anatofuz
parents:
diff changeset
133
anatofuz
parents:
diff changeset
134 // The number of spaces in front of the token or broken part of the token.
anatofuz
parents:
diff changeset
135 // This will be adapted when aligning tokens.
anatofuz
parents:
diff changeset
136 // Can be negative to retain information about the initial relative offset
anatofuz
parents:
diff changeset
137 // of the lines in a block comment. This is used when aligning trailing
anatofuz
parents:
diff changeset
138 // comments. Uncompensated negative offset is truncated to 0.
anatofuz
parents:
diff changeset
139 int Spaces;
anatofuz
parents:
diff changeset
140
anatofuz
parents:
diff changeset
141 // If this change is inside of a token but not at the start of the token or
anatofuz
parents:
diff changeset
142 // directly after a newline.
anatofuz
parents:
diff changeset
143 bool IsInsideToken;
anatofuz
parents:
diff changeset
144
anatofuz
parents:
diff changeset
145 // \c IsTrailingComment, \c TokenLength, \c PreviousEndOfTokenColumn and
anatofuz
parents:
diff changeset
146 // \c EscapedNewlineColumn will be calculated in
anatofuz
parents:
diff changeset
147 // \c calculateLineBreakInformation.
anatofuz
parents:
diff changeset
148 bool IsTrailingComment;
anatofuz
parents:
diff changeset
149 unsigned TokenLength;
anatofuz
parents:
diff changeset
150 unsigned PreviousEndOfTokenColumn;
anatofuz
parents:
diff changeset
151 unsigned EscapedNewlineColumn;
anatofuz
parents:
diff changeset
152
anatofuz
parents:
diff changeset
153 // These fields are used to retain correct relative line indentation in a
anatofuz
parents:
diff changeset
154 // block comment when aligning trailing comments.
anatofuz
parents:
diff changeset
155 //
anatofuz
parents:
diff changeset
156 // If this Change represents a continuation of a block comment,
anatofuz
parents:
diff changeset
157 // \c StartOfBlockComment is pointer to the first Change in the block
anatofuz
parents:
diff changeset
158 // comment. \c IndentationOffset is a relative column offset to this
anatofuz
parents:
diff changeset
159 // change, so that the correct column can be reconstructed at the end of
anatofuz
parents:
diff changeset
160 // the alignment process.
anatofuz
parents:
diff changeset
161 const Change *StartOfBlockComment;
anatofuz
parents:
diff changeset
162 int IndentationOffset;
anatofuz
parents:
diff changeset
163
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
164 // Depth of conditionals. Computed from tracking fake parenthesis, except
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
165 // it does not increase the indent for "chained" conditionals.
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
166 int ConditionalsLevel;
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
167
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
168 // A combination of indent, nesting and conditionals levels, which are used
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
169 // in tandem to compute lexical scope, for the purposes of deciding
150
anatofuz
parents:
diff changeset
170 // when to stop consecutive alignment runs.
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
171 std::tuple<unsigned, unsigned, unsigned> indentAndNestingLevel() const {
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
172 return std::make_tuple(Tok->IndentLevel, Tok->NestingLevel,
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
173 ConditionalsLevel);
150
anatofuz
parents:
diff changeset
174 }
anatofuz
parents:
diff changeset
175 };
anatofuz
parents:
diff changeset
176
anatofuz
parents:
diff changeset
177 private:
223
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
178 struct CellDescription {
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
179 unsigned Index = 0;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
180 unsigned Cell = 0;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
181 unsigned EndIndex = 0;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
182 bool HasSplit = false;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
183 CellDescription *NextColumnElement = nullptr;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
184
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
185 constexpr bool operator==(const CellDescription &Other) const {
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
186 return Index == Other.Index && Cell == Other.Cell &&
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
187 EndIndex == Other.EndIndex;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
188 }
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
189 constexpr bool operator!=(const CellDescription &Other) const {
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
190 return !(*this == Other);
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
191 }
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
192 };
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
193
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
194 struct CellDescriptions {
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
195 SmallVector<CellDescription> Cells;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
196 unsigned CellCount = 0;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
197 unsigned InitialSpaces = 0;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
198 };
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
199
150
anatofuz
parents:
diff changeset
200 /// Calculate \c IsTrailingComment, \c TokenLength for the last tokens
anatofuz
parents:
diff changeset
201 /// or token parts in a line and \c PreviousEndOfTokenColumn and
anatofuz
parents:
diff changeset
202 /// \c EscapedNewlineColumn for the first tokens or token parts in a line.
anatofuz
parents:
diff changeset
203 void calculateLineBreakInformation();
anatofuz
parents:
diff changeset
204
anatofuz
parents:
diff changeset
205 /// \brief Align consecutive C/C++ preprocessor macros over all \c Changes.
anatofuz
parents:
diff changeset
206 void alignConsecutiveMacros();
anatofuz
parents:
diff changeset
207
anatofuz
parents:
diff changeset
208 /// Align consecutive assignments over all \c Changes.
anatofuz
parents:
diff changeset
209 void alignConsecutiveAssignments();
anatofuz
parents:
diff changeset
210
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
211 /// Align consecutive bitfields over all \c Changes.
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
212 void alignConsecutiveBitFields();
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
213
150
anatofuz
parents:
diff changeset
214 /// Align consecutive declarations over all \c Changes.
anatofuz
parents:
diff changeset
215 void alignConsecutiveDeclarations();
anatofuz
parents:
diff changeset
216
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
217 /// Align consecutive declarations over all \c Changes.
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
218 void alignChainedConditionals();
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
219
150
anatofuz
parents:
diff changeset
220 /// Align trailing comments over all \c Changes.
anatofuz
parents:
diff changeset
221 void alignTrailingComments();
anatofuz
parents:
diff changeset
222
anatofuz
parents:
diff changeset
223 /// Align trailing comments from change \p Start to change \p End at
anatofuz
parents:
diff changeset
224 /// the specified \p Column.
anatofuz
parents:
diff changeset
225 void alignTrailingComments(unsigned Start, unsigned End, unsigned Column);
anatofuz
parents:
diff changeset
226
anatofuz
parents:
diff changeset
227 /// Align escaped newlines over all \c Changes.
anatofuz
parents:
diff changeset
228 void alignEscapedNewlines();
anatofuz
parents:
diff changeset
229
anatofuz
parents:
diff changeset
230 /// Align escaped newlines from change \p Start to change \p End at
anatofuz
parents:
diff changeset
231 /// the specified \p Column.
anatofuz
parents:
diff changeset
232 void alignEscapedNewlines(unsigned Start, unsigned End, unsigned Column);
anatofuz
parents:
diff changeset
233
223
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
234 /// Align Array Initializers over all \c Changes.
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
235 void alignArrayInitializers();
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
236
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
237 /// Align Array Initializers from change \p Start to change \p End at
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
238 /// the specified \p Column.
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
239 void alignArrayInitializers(unsigned Start, unsigned End);
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
240
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
241 /// Align Array Initializers being careful to right justify the columns
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
242 /// as described by \p CellDescs.
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
243 void alignArrayInitializersRightJustified(CellDescriptions &&CellDescs);
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
244
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
245 /// Align Array Initializers being careful to leftt justify the columns
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
246 /// as described by \p CellDescs.
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
247 void alignArrayInitializersLeftJustified(CellDescriptions &&CellDescs);
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
248
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
249 /// Calculate the cell width between two indexes.
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
250 unsigned calculateCellWidth(unsigned Start, unsigned End,
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
251 bool WithSpaces = false) const;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
252
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
253 /// Get a set of fully specified CellDescriptions between \p Start and
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
254 /// \p End of the change list.
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
255 CellDescriptions getCells(unsigned Start, unsigned End);
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
256
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
257 /// Does this \p Cell contain a split element?
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
258 static bool isSplitCell(const CellDescription &Cell);
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
259
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
260 /// Get the width of the preceeding cells from \p Start to \p End.
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
261 template <typename I>
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
262 auto getNetWidth(const I &Start, const I &End, unsigned InitialSpaces) const {
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
263 auto NetWidth = InitialSpaces;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
264 for (auto PrevIter = Start; PrevIter != End; ++PrevIter) {
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
265 // If we broke the line the initial spaces are already
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
266 // accounted for.
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
267 if (Changes[PrevIter->Index].NewlinesBefore > 0)
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
268 NetWidth = 0;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
269 NetWidth +=
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
270 calculateCellWidth(PrevIter->Index, PrevIter->EndIndex, true) + 1;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
271 }
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
272 return NetWidth;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
273 }
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
274
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
275 /// Get the maximum width of a cell in a sequence of columns.
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
276 template <typename I>
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
277 unsigned getMaximumCellWidth(I CellIter, unsigned NetWidth) const {
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
278 unsigned CellWidth =
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
279 calculateCellWidth(CellIter->Index, CellIter->EndIndex, true);
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
280 if (Changes[CellIter->Index].NewlinesBefore == 0)
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
281 CellWidth += NetWidth;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
282 for (const auto *Next = CellIter->NextColumnElement; Next != nullptr;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
283 Next = Next->NextColumnElement) {
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
284 auto ThisWidth = calculateCellWidth(Next->Index, Next->EndIndex, true);
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
285 if (Changes[Next->Index].NewlinesBefore == 0)
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
286 ThisWidth += NetWidth;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
287 CellWidth = std::max(CellWidth, ThisWidth);
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
288 }
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
289 return CellWidth;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
290 }
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
291
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
292 /// Get The maximum width of all columns to a given cell.
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
293 template <typename I>
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
294 unsigned getMaximumNetWidth(const I &CellStart, const I &CellStop,
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
295 unsigned InitialSpaces,
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
296 unsigned CellCount) const {
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
297 auto MaxNetWidth = getNetWidth(CellStart, CellStop, InitialSpaces);
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
298 auto RowCount = 1U;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
299 auto Offset = std::distance(CellStart, CellStop);
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
300 for (const auto *Next = CellStop->NextColumnElement; Next != nullptr;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
301 Next = Next->NextColumnElement) {
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
302 auto Start = (CellStart + RowCount * CellCount);
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
303 auto End = Start + Offset;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
304 MaxNetWidth =
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
305 std::max(MaxNetWidth, getNetWidth(Start, End, InitialSpaces));
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
306 ++RowCount;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
307 }
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
308 return MaxNetWidth;
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
309 }
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
310
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
311 /// Align a split cell with a newline to the first element in the cell.
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
312 void alignToStartOfCell(unsigned Start, unsigned End);
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
313
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
314 /// Link the Cell pointers in the list of Cells.
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
315 static CellDescriptions linkCells(CellDescriptions &&CellDesc);
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 173
diff changeset
316
150
anatofuz
parents:
diff changeset
317 /// Fill \c Replaces with the replacements for all effective changes.
anatofuz
parents:
diff changeset
318 void generateChanges();
anatofuz
parents:
diff changeset
319
anatofuz
parents:
diff changeset
320 /// Stores \p Text as the replacement for the whitespace in \p Range.
anatofuz
parents:
diff changeset
321 void storeReplacement(SourceRange Range, StringRef Text);
anatofuz
parents:
diff changeset
322 void appendNewlineText(std::string &Text, unsigned Newlines);
anatofuz
parents:
diff changeset
323 void appendEscapedNewlineText(std::string &Text, unsigned Newlines,
anatofuz
parents:
diff changeset
324 unsigned PreviousEndOfTokenColumn,
anatofuz
parents:
diff changeset
325 unsigned EscapedNewlineColumn);
anatofuz
parents:
diff changeset
326 void appendIndentText(std::string &Text, unsigned IndentLevel,
173
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
327 unsigned Spaces, unsigned WhitespaceStartColumn,
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
328 bool IsAligned);
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
329 unsigned appendTabIndent(std::string &Text, unsigned Spaces,
0572611fdcc8 reorgnization done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
330 unsigned Indentation);
150
anatofuz
parents:
diff changeset
331
anatofuz
parents:
diff changeset
332 SmallVector<Change, 16> Changes;
anatofuz
parents:
diff changeset
333 const SourceManager &SourceMgr;
anatofuz
parents:
diff changeset
334 tooling::Replacements Replaces;
anatofuz
parents:
diff changeset
335 const FormatStyle &Style;
anatofuz
parents:
diff changeset
336 bool UseCRLF;
anatofuz
parents:
diff changeset
337 };
anatofuz
parents:
diff changeset
338
anatofuz
parents:
diff changeset
339 } // namespace format
anatofuz
parents:
diff changeset
340 } // namespace clang
anatofuz
parents:
diff changeset
341
anatofuz
parents:
diff changeset
342 #endif