17#include "llvm/ADT/SmallVector.h"
24 static const char *
const TokNames[] = {
32 llvm_unreachable(
"unknown TokenType");
37 "BINDABLE",
"CONSTANT",
"DESIGNABLE",
"FINAL",
"MEMBER",
38 "NOTIFY",
"READ",
"REQUIRED",
"RESET",
"REVISION",
39 "SCRIPTABLE",
"STORED",
"USER",
"WRITE",
42bool FormatToken::isQtProperty()
const {
49 "clock_t",
"int16_t",
"int32_t",
"int64_t",
"int8_t",
50 "intptr_t",
"ptrdiff_t",
"size_t",
"time_t",
"uint16_t",
51 "uint32_t",
"uint64_t",
"uint8_t",
"uintptr_t",
54bool FormatToken::isTypeName(
const LangOptions &LangOpts)
const {
55 if (
is(TT_TypeName) ||
Tok.isSimpleTypeSpecifier(LangOpts))
58 return (LangOpts.CXXOperatorNames || LangOpts.C11) &&
is(tok::identifier) &&
62bool FormatToken::isTypeOrIdentifier(
const LangOptions &LangOpts)
const {
63 return isTypeName(LangOpts) ||
isOneOf(tok::kw_auto, tok::identifier);
66bool FormatToken::isBlockIndentedInitRBrace(
const FormatStyle &Style)
const {
67 assert(
is(tok::r_brace));
70 if (Style.Cpp11BracedListStyle == FormatStyle::BLS_Block ||
71 !Style.BreakBeforeCloseBracketBracedList) {
77 if (LBrace->Previous && LBrace->Previous->is(tok::equal))
82bool FormatToken::opensBlockOrBlockTypeList(
const FormatStyle &Style)
const {
86 if (
is(TT_TemplateString) && opensScope())
88 return is(TT_ArrayInitializerLSquare) ||
is(TT_ProtoExtensionLSquare) ||
91 (Style.Cpp11BracedListStyle == FormatStyle::BLS_Block &&
93 (
is(tok::less) && Style.isProto());
101 ContinuationIndenter *Indenter,
103 if (!State.NextToken || !State.NextToken->Previous)
106 if (Formats.size() <= 1)
111 State.NextToken->Previous->getPreviousNonComment();
112 if (!LBrace || LBrace->isNoneOf(tok::l_brace, TT_ArrayInitializerLSquare) ||
113 LBrace->is(
BK_Block) || LBrace->is(TT_DictLiteral) ||
114 LBrace->Next->is(TT_DesignatedInitializerPeriod)) {
120 unsigned RemainingCodePoints =
121 Style.ColumnLimit - State.Column + State.NextToken->Previous->ColumnWidth;
124 const ColumnFormat *Format = getColumnFormat(RemainingCodePoints);
133 unsigned Penalty = 0;
136 while (State.NextToken != LBrace->MatchingParen) {
137 bool NewLine =
false;
138 unsigned ExtraSpaces = 0;
141 if (Item < Commas.size() && State.NextToken->Previous == Commas[Item]) {
142 if (!State.NextToken->isTrailingComment()) {
143 ExtraSpaces += Format->ColumnSizes[
Column] - ItemLengths[Item];
149 if (
Column == Format->Columns || State.NextToken->MustBreakBefore) {
155 Penalty += Indenter->addTokenToState(State, NewLine, DryRun, ExtraSpaces);
161 ContinuationIndenter *Indenter,
165 if (Formats.size() == 1 || HasNestedBracedList)
166 State.Stack.back().AvoidBinPacking =
true;
180 if (!
Token->MatchingParen ||
181 Token->isNoneOf(tok::l_brace, TT_ArrayInitializerLSquare)) {
188 if (
Style.Cpp11BracedListStyle != FormatStyle::BLS_Block &&
189 !
Style.BinPackArguments &&
190 (Commas.size() < 19 || !
Style.BinPackLongBracedList)) {
197 if (
Token->
is(TT_ArrayInitializerLSquare) && Commas.size() < 19)
201 if (!
Style.AlignAfterOpenBracket)
205 while (ItemBegin->isTrailingComment())
206 ItemBegin = ItemBegin->Next;
212 MustBreakBeforeItem.reserve(Commas.size() + 1);
213 EndOfLineItemLength.reserve(Commas.size() + 1);
214 ItemLengths.reserve(Commas.size() + 1);
216 bool HasSeparatingComment =
false;
217 for (
unsigned i = 0, e = Commas.size() + 1; i != e; ++i) {
220 while (ItemBegin->HasUnescapedNewline && ItemBegin->isTrailingComment()) {
221 ItemBegin = ItemBegin->Next;
222 HasSeparatingComment = i > 0;
225 MustBreakBeforeItem.push_back(ItemBegin->MustBreakBefore);
226 if (ItemBegin->is(tok::l_brace))
227 HasNestedBracedList =
true;
229 if (i == Commas.size()) {
230 ItemEnd =
Token->MatchingParen;
231 const FormatToken *NonCommentEnd = ItemEnd->getPreviousNonComment();
233 if (
Style.Cpp11BracedListStyle != FormatStyle::BLS_Block &&
234 !ItemEnd->Previous->isTrailingComment()) {
237 while (ItemEnd->Next && !ItemEnd->Next->CanBreakBefore)
238 ItemEnd = ItemEnd->Next;
241 ItemEnd =
Token->MatchingParen->Previous;
249 if (ItemEnd->Next && !ItemEnd->Next->HasUnescapedNewline &&
250 ItemEnd->Next->isTrailingComment()) {
251 ItemEnd = ItemEnd->Next;
257 if (ItemEnd->getNextNonComment() ==
Token->MatchingParen)
259 ItemBegin = ItemEnd->Next;
264 if (Commas.size() < 5 || HasSeparatingComment)
267 if (
Token->NestingLevel != 0 &&
Token->
is(tok::l_brace) && Commas.size() < 19)
272 unsigned MaxItems =
Style.ColumnLimit / 3;
274 MinSizeInColumn.reserve(MaxItems);
275 for (
unsigned Columns = 1; Columns <= MaxItems; ++Columns) {
277 Format.Columns = Columns;
278 Format.ColumnSizes.resize(Columns);
279 MinSizeInColumn.assign(Columns,
UINT_MAX);
280 Format.LineCount = 1;
281 bool HasRowWithSufficientColumns =
false;
283 for (
unsigned i = 0, e = ItemLengths.size(); i != e; ++i) {
284 assert(i < MustBreakBeforeItem.size());
285 if (MustBreakBeforeItem[i] ||
Column == Columns) {
289 if (
Column == Columns - 1)
290 HasRowWithSufficientColumns =
true;
292 (
Column == Columns - 1) ? EndOfLineItemLength[i] : ItemLengths[i];
293 Format.ColumnSizes[
Column] = std::max(Format.ColumnSizes[
Column], Length);
294 MinSizeInColumn[
Column] = std::min(MinSizeInColumn[
Column], Length);
299 if (!HasRowWithSufficientColumns)
301 Format.TotalWidth = Columns - 1;
303 for (
unsigned i = 0; i < Columns; ++i)
304 Format.TotalWidth += Format.ColumnSizes[i];
309 for (
unsigned i = 0; i < Columns - 1; ++i)
310 if (Format.ColumnSizes[i] - MinSizeInColumn[i] > 10)
318 if (Format.TotalWidth >
Style.ColumnLimit && Columns > 1)
321 Formats.push_back(Format);
325const CommaSeparatedList::ColumnFormat *
326CommaSeparatedList::getColumnFormat(
unsigned RemainingCharacters)
const {
327 const ColumnFormat *BestFormat =
nullptr;
328 for (
const ColumnFormat &Format : llvm::reverse(Formats)) {
329 if (Format.TotalWidth <= RemainingCharacters || Format.Columns == 1) {
330 if (BestFormat && Format.LineCount > BestFormat->LineCount)
332 BestFormat = &Format;
341 if (Current.
is(TT_CtorInitializerComma) &&
342 Style.BreakConstructorInitializers == FormatStyle::BCIS_BeforeComma) {
345 if (Style.Language == FormatStyle::LK_Proto && Current.
is(TT_SelectorName))
347 if (Current.
is(TT_QtProperty))
349 return Previous.is(tok::comma) && !Current.isTrailingComment() &&
350 ((
Previous.isNot(TT_CtorInitializerComma) ||
351 Style.BreakConstructorInitializers !=
352 FormatStyle::BCIS_BeforeComma) &&
353 (
Previous.isNot(TT_InheritanceComma) ||
354 Style.BreakInheritanceList != FormatStyle::BILS_BeforeComma));
This file implements an indenter that manages the indentation of continuations.
static constexpr bool isOneOf()
static const char *const TokNames[]
unsigned formatFromToken(LineState &State, ContinuationIndenter *Indenter, bool DryRun) override
Apply the special formatting that the given role demands.
unsigned formatAfterToken(LineState &State, ContinuationIndenter *Indenter, bool DryRun) override
Same as formatFromToken, but assumes that the first token has already been set thereby deciding on th...
void precomputeFormattingInfos(const FormatToken *Token) override
After the TokenAnnotator has finished annotating all the tokens, this function precomputes required i...
Keeps track of the various options that can be enabled, which controls the dialect of C or C++ that i...
virtual void precomputeFormattingInfos(const FormatToken *Token)
After the TokenAnnotator has finished annotating all the tokens, this function precomputes required i...
const FormatStyle & Style
Token - This structure provides full information about a lexed token.
bool is(tok::TokenKind K) const
is/isNot - Predicates to check if this token is a specific kind, as in "if (Tok.is(tok::l_brace)) {....
The base class of the type hierarchy.
The JSON file list parser is used to communicate input to InstallAPI.