|  | //===--- BracesAroundStatement.h - clang-tidy ------- -----------*- C++ -*-===// | 
|  | // | 
|  | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. | 
|  | // See https://llvm.org/LICENSE.txt for license information. | 
|  | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  | /// | 
|  | /// \file | 
|  | /// This file provides utilities to put braces around a statement. | 
|  | /// | 
|  | //===----------------------------------------------------------------------===// | 
|  |  | 
|  | #include "clang/AST/Stmt.h" | 
|  | #include "clang/Basic/Diagnostic.h" | 
|  | #include "clang/Basic/SourceLocation.h" | 
|  | #include "clang/Basic/SourceManager.h" | 
|  |  | 
|  | namespace clang::tidy::utils { | 
|  |  | 
|  | /// A provider of fix-it hints to insert opening and closing braces. An instance | 
|  | /// of this type is the result of calling `getBraceInsertionsHints` below. | 
|  | struct BraceInsertionHints { | 
|  | /// The position of a potential diagnostic. It coincides with the position of | 
|  | /// the opening brace to insert, but can also just be the place to show a | 
|  | /// diagnostic in case braces cannot be inserted automatically. | 
|  | SourceLocation DiagnosticPos; | 
|  |  | 
|  | /// Constructor for a no-hint. | 
|  | BraceInsertionHints() = default; | 
|  |  | 
|  | /// Constructor for a valid hint that cannot insert braces automatically. | 
|  | BraceInsertionHints(SourceLocation DiagnosticPos) | 
|  | : DiagnosticPos(DiagnosticPos) {} | 
|  |  | 
|  | /// Constructor for a hint offering fix-its for brace insertion. Both | 
|  | /// positions must be valid. | 
|  | BraceInsertionHints(SourceLocation OpeningBracePos, | 
|  | SourceLocation ClosingBracePos, std::string ClosingBrace) | 
|  | : DiagnosticPos(OpeningBracePos), OpeningBracePos(OpeningBracePos), | 
|  | ClosingBracePos(ClosingBracePos), ClosingBrace(ClosingBrace) { | 
|  | assert(offersFixIts()); | 
|  | } | 
|  |  | 
|  | /// Indicates whether the hint provides at least the position of a diagnostic. | 
|  | operator bool() const; | 
|  |  | 
|  | /// Indicates whether the hint provides fix-its to insert braces. | 
|  | bool offersFixIts() const; | 
|  |  | 
|  | /// The number of lines between the inserted opening brace and its closing | 
|  | /// counterpart. | 
|  | unsigned resultingCompoundLineExtent(const SourceManager &SourceMgr) const; | 
|  |  | 
|  | /// Fix-it to insert an opening brace. | 
|  | FixItHint openingBraceFixIt() const; | 
|  |  | 
|  | /// Fix-it to insert a closing brace. | 
|  | FixItHint closingBraceFixIt() const; | 
|  |  | 
|  | private: | 
|  | SourceLocation OpeningBracePos; | 
|  | SourceLocation ClosingBracePos; | 
|  | std::string ClosingBrace; | 
|  | }; | 
|  |  | 
|  | /// Create fix-it hints for braces that wrap the given statement when applied. | 
|  | /// The algorithm computing them respects comment before and after the statement | 
|  | /// and adds line breaks before the braces accordingly. | 
|  | BraceInsertionHints | 
|  | getBraceInsertionsHints(const Stmt *const S, const LangOptions &LangOpts, | 
|  | const SourceManager &SM, SourceLocation StartLoc, | 
|  | SourceLocation EndLocHint = SourceLocation()); | 
|  |  | 
|  | } // namespace clang::tidy::utils |