//===--- USRLocFinder.h - Clang refactoring library -----------------------===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// /// /// \file /// \brief Provides functionality for finding all instances of a USR in a given /// AST. /// //===----------------------------------------------------------------------===// #ifndef LLVM_CLANG_TOOLING_REFACTOR_RENAME_USR_LOC_FINDER_H #define LLVM_CLANG_TOOLING_REFACTOR_RENAME_USR_LOC_FINDER_H #include "clang/AST/AST.h" #include "clang/Tooling/Core/Replacement.h" #include "clang/Tooling/Refactoring/AtomicChange.h" #include "llvm/ADT/StringRef.h" #include #include namespace clang { namespace tooling { /// Create atomic changes for renaming all symbol references which are /// identified by the USRs set to a given new name. /// /// \param USRs The set containing USRs of a particular old symbol. /// \param NewName The new name to replace old symbol name. /// \param TranslationUnitDecl The translation unit declaration. /// /// \return Atomic changes for renaming. std::vector createRenameAtomicChanges(llvm::ArrayRef USRs, llvm::StringRef NewName, Decl *TranslationUnitDecl); // FIXME: make this an AST matcher. Wouldn't that be awesome??? I agree! std::vector getLocationsOfUSRs(const std::vector &USRs, llvm::StringRef PrevName, Decl *Decl); } // end namespace tooling } // end namespace clang #endif // LLVM_CLANG_TOOLING_REFACTOR_RENAME_USR_LOC_FINDER_H