//===--- FixIt.h - FixIt Hint utilities -------------------------*- 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 // //===----------------------------------------------------------------------===// // // This file implements functions to ease source rewriting from AST-nodes. // // Example swapping A and B expressions: // // Expr *A, *B; // tooling::fixit::createReplacement(*A, *B); // tooling::fixit::createReplacement(*B, *A); // //===----------------------------------------------------------------------===// #ifndef LLVM_CLANG_TOOLING_FIXIT_H #define LLVM_CLANG_TOOLING_FIXIT_H #include "clang/AST/ASTContext.h" namespace clang { namespace tooling { namespace fixit { namespace internal { StringRef getText(CharSourceRange Range, const ASTContext &Context); /// Returns the token CharSourceRange corresponding to \p Range. inline CharSourceRange getSourceRange(const SourceRange &Range) { return CharSourceRange::getTokenRange(Range); } /// Returns the CharSourceRange of the token at Location \p Loc. inline CharSourceRange getSourceRange(const SourceLocation &Loc) { return CharSourceRange::getTokenRange(Loc, Loc); } /// Returns the CharSourceRange of an given Node. \p Node is typically a /// 'Stmt', 'Expr' or a 'Decl'. template CharSourceRange getSourceRange(const T &Node) { return CharSourceRange::getTokenRange(Node.getSourceRange()); } } // end namespace internal /// Returns a textual representation of \p Node. template StringRef getText(const T &Node, const ASTContext &Context) { return internal::getText(internal::getSourceRange(Node), Context); } // Returns a FixItHint to remove \p Node. // TODO: Add support for related syntactical elements (i.e. comments, ...). template FixItHint createRemoval(const T &Node) { return FixItHint::CreateRemoval(internal::getSourceRange(Node)); } // Returns a FixItHint to replace \p Destination by \p Source. template FixItHint createReplacement(const D &Destination, const S &Source, const ASTContext &Context) { return FixItHint::CreateReplacement(internal::getSourceRange(Destination), getText(Source, Context)); } // Returns a FixItHint to replace \p Destination by \p Source. template FixItHint createReplacement(const D &Destination, StringRef Source) { return FixItHint::CreateReplacement(internal::getSourceRange(Destination), Source); } } // end namespace fixit } // end namespace tooling } // end namespace clang #endif // LLVM_CLANG_TOOLING_FIXINT_H