File: document_link.h

package info (click to toggle)
asymptote 3.02%2Bds-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 33,400 kB
  • sloc: cpp: 172,516; ansic: 69,728; python: 14,967; sh: 5,599; javascript: 4,866; lisp: 1,507; perl: 1,417; makefile: 1,028; yacc: 610; lex: 449; xml: 182; asm: 8
file content (44 lines) | stat: -rw-r--r-- 1,386 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
#pragma once

#include "LibLsp/JsonRpc/RequestInMessage.h"
#include "LibLsp/JsonRpc/lsResponseMessage.h"
#include "LibLsp/lsp/lsTextDocumentIdentifier.h"
#include "LibLsp/lsp/lsRange.h"
#include "LibLsp/lsp/lsAny.h"

namespace TextDocumentDocumentLink
{

struct Params
{
    // The document to provide document links for.
    lsTextDocumentIdentifier textDocument;
    MAKE_SWAP_METHOD(Params, textDocument)
};

}; // namespace TextDocumentDocumentLink
MAKE_REFLECT_STRUCT(TextDocumentDocumentLink::Params, textDocument);

// A document link is a range in a text document that links to an internal or
// external resource, like another text document or a web site.
struct lsDocumentLink
{
    // The range this link applies to.
    lsRange range;
    // The uri this link points to. If missing a resolve request is sent later.
    optional<lsDocumentUri> target;

    optional<lsp::Any> data;

    MAKE_SWAP_METHOD(lsDocumentLink, range, target, data)
};
MAKE_REFLECT_STRUCT(lsDocumentLink, range, target, data);

DEFINE_REQUEST_RESPONSE_TYPE(
    td_links, TextDocumentDocumentLink::Params, std::vector<lsDocumentLink>, "textDocument/documentLink"
);

/**
 * The document link resolve request is sent from the client to the server to resolve the target of a given document link.
 */
DEFINE_REQUEST_RESPONSE_TYPE(td_linkResolve, lsDocumentLink, lsDocumentLink, "documentLink/resolve");