clang  19.0.0git
FixIt.h
Go to the documentation of this file.
1 //===--- FixIt.h - FixIt Hint utilities -------------------------*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 //
9 // This file implements functions to ease source rewriting from AST-nodes.
10 //
11 // Example swapping A and B expressions:
12 //
13 // Expr *A, *B;
14 // tooling::fixit::createReplacement(*A, *B);
15 // tooling::fixit::createReplacement(*B, *A);
16 //
17 //===----------------------------------------------------------------------===//
18 
19 #ifndef LLVM_CLANG_TOOLING_FIXIT_H
20 #define LLVM_CLANG_TOOLING_FIXIT_H
21 
22 #include "clang/AST/ASTContext.h"
23 
24 namespace clang {
25 namespace tooling {
26 namespace fixit {
27 
28 namespace internal {
29 StringRef getText(CharSourceRange Range, const ASTContext &Context);
30 
31 /// Returns the token CharSourceRange corresponding to \p Range.
34 }
35 
36 /// Returns the CharSourceRange of the token at Location \p Loc.
39 }
40 
41 /// Returns the CharSourceRange of an given Node. \p Node is typically a
42 /// 'Stmt', 'Expr' or a 'Decl'.
43 template <typename T> CharSourceRange getSourceRange(const T &Node) {
44  return CharSourceRange::getTokenRange(Node.getSourceRange());
45 }
46 } // end namespace internal
47 
48 /// Returns a textual representation of \p Node.
49 template <typename T>
50 StringRef getText(const T &Node, const ASTContext &Context) {
52 }
53 
54 // Returns a FixItHint to remove \p Node.
55 // TODO: Add support for related syntactical elements (i.e. comments, ...).
56 template <typename T> FixItHint createRemoval(const T &Node) {
58 }
59 
60 // Returns a FixItHint to replace \p Destination by \p Source.
61 template <typename D, typename S>
62 FixItHint createReplacement(const D &Destination, const S &Source,
63  const ASTContext &Context) {
65  getText(Source, Context));
66 }
67 
68 // Returns a FixItHint to replace \p Destination by \p Source.
69 template <typename D>
70 FixItHint createReplacement(const D &Destination, StringRef Source) {
72  Source);
73 }
74 
75 } // end namespace fixit
76 } // end namespace tooling
77 } // end namespace clang
78 
79 #endif // LLVM_CLANG_TOOLING_FIXIT_H
Defines the clang::ASTContext interface.
DynTypedNode Node
SourceLocation Loc
Definition: SemaObjC.cpp:755
Holds long-lived AST nodes (such as types and decls) that can be referred to throughout the semantic ...
Definition: ASTContext.h:185
Represents a character-granular source range.
static CharSourceRange getTokenRange(SourceRange R)
Annotates a diagnostic with some code that should be inserted, removed, or replaced to fix the proble...
Definition: Diagnostic.h:72
static FixItHint CreateReplacement(CharSourceRange RemoveRange, StringRef Code)
Create a code modification hint that replaces the given source range with the given code string.
Definition: Diagnostic.h:135
static FixItHint CreateRemoval(CharSourceRange RemoveRange)
Create a code modification hint that removes the given source range.
Definition: Diagnostic.h:124
Encodes a location in the source.
A trivial tuple used to represent a source range.
A source range independent of the SourceManager.
Definition: Replacement.h:44
StringRef getText(CharSourceRange Range, const ASTContext &Context)
Definition: FixIt.cpp:21
CharSourceRange getSourceRange(const SourceRange &Range)
Returns the token CharSourceRange corresponding to Range.
Definition: FixIt.h:32
FixItHint createReplacement(const D &Destination, const S &Source, const ASTContext &Context)
Definition: FixIt.h:62
FixItHint createRemoval(const T &Node)
Definition: FixIt.h:56
StringRef getText(const T &Node, const ASTContext &Context)
Returns a textual representation of Node.
Definition: FixIt.h:50
The JSON file list parser is used to communicate input to InstallAPI.
const FunctionProtoType * T