2019-06-26 21:08:36 +08:00
|
|
|
//==-- SemanticHighlighting.h - Generating highlights from the AST-- 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
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
2019-07-04 15:53:12 +08:00
|
|
|
//
|
|
|
|
// An implementation of semantic highlighting based on this proposal:
|
|
|
|
// https://github.com/microsoft/vscode-languageserver-node/pull/367 in clangd.
|
|
|
|
// Semantic highlightings are calculated for an AST by visiting every AST node
|
|
|
|
// and classifying nodes that are interesting to highlight (variables/function
|
|
|
|
// calls etc.).
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
2019-06-26 21:08:36 +08:00
|
|
|
|
2019-06-27 20:22:18 +08:00
|
|
|
#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANGD_SEMANTICHIGHLIGHTING_H
|
|
|
|
#define LLVM_CLANG_TOOLS_EXTRA_CLANGD_SEMANTICHIGHLIGHTING_H
|
2019-06-26 21:08:36 +08:00
|
|
|
|
|
|
|
#include "ClangdUnit.h"
|
2019-07-04 15:53:12 +08:00
|
|
|
#include "Protocol.h"
|
2019-06-26 21:08:36 +08:00
|
|
|
|
|
|
|
namespace clang {
|
|
|
|
namespace clangd {
|
|
|
|
|
|
|
|
enum class HighlightingKind {
|
2019-07-04 15:53:12 +08:00
|
|
|
Variable = 0,
|
2019-07-04 20:27:21 +08:00
|
|
|
Function,
|
2019-07-15 16:12:21 +08:00
|
|
|
Method,
|
|
|
|
Field,
|
2019-07-10 16:41:25 +08:00
|
|
|
Class,
|
|
|
|
Enum,
|
2019-07-15 15:41:12 +08:00
|
|
|
EnumConstant,
|
2019-07-11 17:29:16 +08:00
|
|
|
Namespace,
|
2019-07-18 17:56:38 +08:00
|
|
|
TemplateParameter,
|
2019-07-04 20:27:21 +08:00
|
|
|
|
|
|
|
NumKinds,
|
2019-06-26 21:08:36 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
// Contains all information needed for the highlighting a token.
|
|
|
|
struct HighlightingToken {
|
|
|
|
HighlightingKind Kind;
|
|
|
|
Range R;
|
|
|
|
};
|
|
|
|
|
2019-08-01 16:08:44 +08:00
|
|
|
bool operator==(const HighlightingToken &L, const HighlightingToken &R);
|
|
|
|
bool operator<(const HighlightingToken &L, const HighlightingToken &R);
|
|
|
|
|
|
|
|
/// Contains all information about highlightings on a single line.
|
|
|
|
struct LineHighlightings {
|
|
|
|
int Line;
|
|
|
|
std::vector<HighlightingToken> Tokens;
|
|
|
|
};
|
|
|
|
|
|
|
|
bool operator==(const LineHighlightings &L, const LineHighlightings &R);
|
2019-06-26 21:08:36 +08:00
|
|
|
|
|
|
|
// Returns all HighlightingTokens from an AST. Only generates highlights for the
|
|
|
|
// main AST.
|
|
|
|
std::vector<HighlightingToken> getSemanticHighlightings(ParsedAST &AST);
|
|
|
|
|
2019-07-04 20:27:21 +08:00
|
|
|
/// Converts a HighlightingKind to a corresponding TextMate scope
|
|
|
|
/// (https://manual.macromates.com/en/language_grammars).
|
|
|
|
llvm::StringRef toTextMateScope(HighlightingKind Kind);
|
2019-07-04 15:53:12 +08:00
|
|
|
|
2019-08-01 16:08:44 +08:00
|
|
|
/// Convert to LSP's semantic highlighting information.
|
2019-07-04 15:53:12 +08:00
|
|
|
std::vector<SemanticHighlightingInformation>
|
2019-08-01 16:08:44 +08:00
|
|
|
toSemanticHighlightingInformation(llvm::ArrayRef<LineHighlightings> Tokens);
|
|
|
|
|
|
|
|
/// Return a line-by-line diff between two highlightings.
|
|
|
|
/// - if the tokens on a line are the same in both hightlightings, this line is
|
|
|
|
/// omitted.
|
|
|
|
/// - if a line exists in New but not in Old the tokens on this line are
|
|
|
|
/// emitted.
|
|
|
|
/// - if a line does not exists in New but exists in Old an empty line is
|
|
|
|
/// emitted (to tell client to clear the previous highlightings on this line).
|
|
|
|
/// \p NewMaxLine is the maximum line number from the new file.
|
|
|
|
/// REQUIRED: Old and New are sorted.
|
|
|
|
std::vector<LineHighlightings>
|
|
|
|
diffHighlightings(ArrayRef<HighlightingToken> New,
|
|
|
|
ArrayRef<HighlightingToken> Old, int NewMaxLine);
|
2019-07-04 15:53:12 +08:00
|
|
|
|
2019-06-26 21:08:36 +08:00
|
|
|
} // namespace clangd
|
|
|
|
} // namespace clang
|
|
|
|
|
|
|
|
#endif
|