2018-03-09 22:00:34 +08:00
|
|
|
//===--- AST.h - Utility AST functions -------------------------*- C++ -*-===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// 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
|
2018-03-09 22:00:34 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// Various code that examines C++ source code using AST.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANGD_AST_H_
|
|
|
|
#define LLVM_CLANG_TOOLS_EXTRA_CLANGD_AST_H_
|
|
|
|
|
2019-02-28 21:49:25 +08:00
|
|
|
#include "index/SymbolID.h"
|
2018-06-22 18:46:59 +08:00
|
|
|
#include "clang/AST/Decl.h"
|
2018-03-09 22:00:34 +08:00
|
|
|
#include "clang/Basic/SourceLocation.h"
|
2019-02-28 21:49:25 +08:00
|
|
|
#include "clang/Lex/MacroInfo.h"
|
2018-03-09 22:00:34 +08:00
|
|
|
|
|
|
|
namespace clang {
|
|
|
|
class SourceManager;
|
|
|
|
class Decl;
|
|
|
|
|
|
|
|
namespace clangd {
|
|
|
|
|
2018-10-18 20:23:05 +08:00
|
|
|
/// Returns true if the declaration is considered implementation detail based on
|
|
|
|
/// heuristics. For example, a declaration whose name is not explicitly spelled
|
|
|
|
/// in code is considered implementation detail.
|
|
|
|
bool isImplementationDetail(const Decl *D);
|
|
|
|
|
2018-03-09 22:00:34 +08:00
|
|
|
/// Find the identifier source location of the given D.
|
|
|
|
///
|
|
|
|
/// The returned location is usually the spelling location where the name of the
|
|
|
|
/// decl occurs in the code.
|
2019-08-07 04:25:59 +08:00
|
|
|
SourceLocation findName(const clang::Decl *D);
|
2018-03-09 22:00:34 +08:00
|
|
|
|
2018-06-22 18:46:59 +08:00
|
|
|
/// Returns the qualified name of ND. The scope doesn't contain unwritten scopes
|
|
|
|
/// like inline namespaces.
|
|
|
|
std::string printQualifiedName(const NamedDecl &ND);
|
|
|
|
|
2018-10-17 19:19:02 +08:00
|
|
|
/// Returns the first enclosing namespace scope starting from \p DC.
|
|
|
|
std::string printNamespaceScope(const DeclContext &DC);
|
|
|
|
|
2018-11-23 23:21:19 +08:00
|
|
|
/// Prints unqualified name of the decl for the purpose of displaying it to the
|
|
|
|
/// user. Anonymous decls return names of the form "(anonymous {kind})", e.g.
|
|
|
|
/// "(anonymous struct)" or "(anonymous namespace)".
|
|
|
|
std::string printName(const ASTContext &Ctx, const NamedDecl &ND);
|
|
|
|
|
2019-04-12 18:09:14 +08:00
|
|
|
/// Prints template arguments of a decl as written in the source code, including
|
|
|
|
/// enclosing '<' and '>', e.g for a partial specialization like: template
|
|
|
|
/// <typename U> struct Foo<int, U> will return '<int, U>'. Returns an empty
|
|
|
|
/// string if decl is not a template specialization.
|
|
|
|
std::string printTemplateSpecializationArgs(const NamedDecl &ND);
|
|
|
|
|
2018-08-07 16:57:52 +08:00
|
|
|
/// Gets the symbol ID for a declaration, if possible.
|
|
|
|
llvm::Optional<SymbolID> getSymbolID(const Decl *D);
|
|
|
|
|
2018-09-06 17:59:37 +08:00
|
|
|
/// Gets the symbol ID for a macro, if possible.
|
|
|
|
/// Currently, this is an encoded USR of the macro, which incorporates macro
|
|
|
|
/// locations (e.g. file name, offset in file).
|
|
|
|
/// FIXME: the USR semantics might not be stable enough as the ID for index
|
|
|
|
/// macro (e.g. a change in definition offset can result in a different USR). We
|
|
|
|
/// could change these semantics in the future by reimplementing this funcure
|
|
|
|
/// (e.g. avoid USR for macros).
|
|
|
|
llvm::Optional<SymbolID> getSymbolID(const IdentifierInfo &II,
|
|
|
|
const MacroInfo *MI,
|
|
|
|
const SourceManager &SM);
|
|
|
|
|
2019-07-18 23:13:45 +08:00
|
|
|
/// Returns a QualType as string. The result doesn't contain unwritten scopes
|
|
|
|
/// like annoymous/inline namespace.
|
2019-07-12 00:04:18 +08:00
|
|
|
std::string printType(const QualType QT, const DeclContext & Context);
|
|
|
|
|
|
|
|
/// Try to shorten the OriginalName by removing namespaces from the left of
|
|
|
|
/// the string that are redundant in the CurrentNamespace. This way the type
|
|
|
|
/// idenfier become shorter and easier to read.
|
|
|
|
/// Limitation: It only handles the qualifier of the type itself, not that of
|
|
|
|
/// templates.
|
|
|
|
/// FIXME: change type of parameter CurrentNamespace to DeclContext ,
|
|
|
|
/// take in to account using directives etc
|
|
|
|
/// Example: shortenNamespace("ns1::MyClass<ns1::OtherClass>", "ns1")
|
|
|
|
/// --> "MyClass<ns1::OtherClass>"
|
2019-08-08 15:21:06 +08:00
|
|
|
std::string shortenNamespace(const llvm::StringRef OriginalName,
|
|
|
|
const llvm::StringRef CurrentNamespace);
|
|
|
|
|
|
|
|
/// Indicates if \p D is a template instantiation implicitly generated by the
|
|
|
|
/// compiler, e.g.
|
|
|
|
/// template <class T> struct vector {};
|
|
|
|
/// vector<int> v; // 'vector<int>' is an implicit instantiation
|
|
|
|
bool isImplicitTemplateInstantiation(const NamedDecl *D);
|
|
|
|
/// Indicates if \p D is an explicit template specialization, e.g.
|
|
|
|
/// template <class T> struct vector {};
|
|
|
|
/// template <> struct vector<bool> {}; // <-- explicit specialization
|
|
|
|
///
|
|
|
|
/// Note that explicit instantiations are NOT explicit specializations, albeit
|
|
|
|
/// they look similar.
|
|
|
|
/// template struct vector<bool>; // <-- explicit instantiation, NOT an
|
|
|
|
/// explicit specialization.
|
|
|
|
bool isExplicitTemplateSpecialization(const NamedDecl *D);
|
2019-07-12 00:04:18 +08:00
|
|
|
|
2018-03-09 22:00:34 +08:00
|
|
|
} // namespace clangd
|
|
|
|
} // namespace clang
|
|
|
|
|
|
|
|
#endif // LLVM_CLANG_TOOLS_EXTRA_CLANGD_AST_H_
|