]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - contrib/llvm/tools/clang/include/clang/Tooling/FixIt.h
Merge clang 7.0.1 and several follow-up changes
[FreeBSD/FreeBSD.git] / contrib / llvm / tools / clang / include / clang / Tooling / FixIt.h
1 //===--- FixIt.h - FixIt Hint utilities -------------------------*- C++ -*-===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 //  This file implements functions to ease source rewriting from AST-nodes.
11 //
12 //  Example swapping A and B expressions:
13 //
14 //    Expr *A, *B;
15 //    tooling::fixit::createReplacement(*A, *B);
16 //    tooling::fixit::createReplacement(*B, *A);
17 //
18 //===----------------------------------------------------------------------===//
19
20 #ifndef LLVM_CLANG_TOOLING_FIXIT_H
21 #define LLVM_CLANG_TOOLING_FIXIT_H
22
23 #include "clang/AST/ASTContext.h"
24
25 namespace clang {
26 namespace tooling {
27 namespace fixit {
28
29 namespace internal {
30 StringRef getText(SourceRange Range, const ASTContext &Context);
31
32 /// Returns the SourceRange of a SourceRange. This identity function is
33 ///        used by the following template abstractions.
34 inline SourceRange getSourceRange(const SourceRange &Range) { return Range; }
35
36 /// Returns the SourceRange of the token at Location \p Loc.
37 inline SourceRange getSourceRange(const SourceLocation &Loc) {
38   return SourceRange(Loc);
39 }
40
41 /// Returns the SourceRange of an given Node. \p Node is typically a
42 ///        'Stmt', 'Expr' or a 'Decl'.
43 template <typename T> SourceRange getSourceRange(const T &Node) {
44   return 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) {
51   return internal::getText(internal::getSourceRange(Node), 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) {
57   return FixItHint::CreateRemoval(internal::getSourceRange(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) {
64   return FixItHint::CreateReplacement(internal::getSourceRange(Destination),
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) {
71   return FixItHint::CreateReplacement(internal::getSourceRange(Destination),
72                                       Source);
73 }
74
75 } // end namespace fixit
76 } // end namespace tooling
77 } // end namespace clang
78
79 #endif // LLVM_CLANG_TOOLING_FIXINT_H