2020-10-17 02:03:48 +08:00
|
|
|
//===--- DumpAST.h - Serialize clang AST to LSP -----------------*- 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
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// Exposing clang's AST can give insight into the precise meaning of code.
|
|
|
|
// (C++ is a complicated language, and very few people know all its rules).
|
|
|
|
// Despite the name, clang's AST describes *semantics* and so includes nodes
|
|
|
|
// for implicit behavior like conversions.
|
|
|
|
//
|
|
|
|
// It's also useful to developers who work with the clang AST specifically,
|
|
|
|
// and want to know how certain constructs are represented.
|
|
|
|
//
|
|
|
|
// The main representation is not based on the familiar -ast-dump output,
|
|
|
|
// which is heavy on internal details.
|
|
|
|
// It also does not use the -ast-dump=json output, which captures the same
|
|
|
|
// detail in a machine-friendly way, but requires client-side logic to present.
|
|
|
|
// Instead, the key information is bundled into a few fields (role/kind/detail)
|
|
|
|
// with weakly-defined semantics, optimized for easy presentation.
|
|
|
|
// The -ast-dump output is preserved in the 'arcana' field, and may be shown
|
|
|
|
// e.g. as a tooltip.
|
|
|
|
//
|
|
|
|
// The textDocument/ast method implemented here is a clangd extension.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANGD_DUMPAST_H
|
|
|
|
#define LLVM_CLANG_TOOLS_EXTRA_CLANGD_DUMPAST_H
|
|
|
|
|
|
|
|
#include "Protocol.h"
|
|
|
|
#include "clang/AST/ASTContext.h"
|
|
|
|
|
|
|
|
namespace clang {
|
|
|
|
namespace syntax {
|
|
|
|
class TokenBuffer;
|
|
|
|
} // namespace syntax
|
|
|
|
namespace clangd {
|
|
|
|
|
2021-04-24 03:17:43 +08:00
|
|
|
// Note: It's safe for the node to be a TranslationUnitDecl, as this function
|
|
|
|
// does not deserialize the preamble.
|
2020-10-17 02:03:48 +08:00
|
|
|
ASTNode dumpAST(const DynTypedNode &, const syntax::TokenBuffer &Tokens,
|
|
|
|
const ASTContext &);
|
|
|
|
|
|
|
|
} // namespace clangd
|
|
|
|
} // namespace clang
|
|
|
|
|
|
|
|
#endif
|