1
0
Fork 0
php-language-server/src/Server/TextDocument.php

115 lines
3.6 KiB
PHP
Raw Normal View History

2016-08-23 09:21:37 +00:00
<?php
declare(strict_types = 1);
2016-08-23 09:21:37 +00:00
namespace LanguageServer\Server;
2016-08-23 09:21:37 +00:00
use LanguageServer\{LanguageClient, ColumnCalculator, Project};
use LanguageServer\Protocol\{
TextDocumentItem,
TextDocumentIdentifier,
VersionedTextDocumentIdentifier,
Diagnostic,
DiagnosticSeverity,
Range,
2016-09-06 10:54:34 +00:00
Position,
FormattingOptions,
2016-10-08 12:59:08 +00:00
TextEdit,
Location
};
2016-08-25 13:27:14 +00:00
2016-08-23 09:21:37 +00:00
/**
* Provides method handlers for all textDocument/* methods
*/
class TextDocument
2016-08-23 09:21:37 +00:00
{
/**
* The lanugage client object to call methods on the client
*
2016-09-04 10:27:56 +00:00
* @var \LanguageServer\LanguageClient
*/
private $client;
/**
* @var Project
*/
private $project;
public function __construct(Project $project, LanguageClient $client)
2016-08-25 13:27:14 +00:00
{
$this->project = $project;
$this->client = $client;
2016-08-25 13:27:14 +00:00
}
2016-08-23 09:21:37 +00:00
/**
* The document symbol request is sent from the client to the server to list all symbols found in a given text
* document.
*
2016-09-04 10:27:56 +00:00
* @param \LanguageServer\Protocol\TextDocumentIdentifier $textDocument
2016-08-23 09:21:37 +00:00
* @return SymbolInformation[]
*/
2016-08-25 13:27:14 +00:00
public function documentSymbol(TextDocumentIdentifier $textDocument): array
2016-08-23 09:21:37 +00:00
{
return $this->project->getDocument($textDocument->uri)->getSymbols();
2016-08-25 13:27:14 +00:00
}
2016-08-23 09:21:37 +00:00
2016-08-25 13:27:14 +00:00
/**
* The document open notification is sent from the client to the server to signal newly opened text documents. The
* document's truth is now managed by the client and the server must not try to read the document's truth using the
* document's uri.
*
2016-09-04 10:27:56 +00:00
* @param \LanguageServer\Protocol\TextDocumentItem $textDocument The document that was opened.
2016-08-25 13:27:14 +00:00
* @return void
*/
public function didOpen(TextDocumentItem $textDocument)
{
$this->project->getDocument($textDocument->uri)->updateContent($textDocument->text);
2016-08-25 13:27:14 +00:00
}
/**
* The document change notification is sent from the client to the server to signal changes to a text document.
*
2016-09-04 10:27:56 +00:00
* @param \LanguageServer\Protocol\VersionedTextDocumentIdentifier $textDocument
* @param \LanguageServer\Protocol\TextDocumentContentChangeEvent[] $contentChanges
2016-08-25 13:27:14 +00:00
* @return void
*/
public function didChange(VersionedTextDocumentIdentifier $textDocument, array $contentChanges)
{
$this->project->getDocument($textDocument->uri)->updateContent($contentChanges[0]->text);
2016-08-25 13:27:14 +00:00
}
2016-09-06 10:54:34 +00:00
/**
* The document formatting request is sent from the server to the client to format a whole document.
*
* @param TextDocumentIdentifier $textDocument The document to format
* @param FormattingOptions $options The format options
* @return TextEdit[]
*/
public function formatting(TextDocumentIdentifier $textDocument, FormattingOptions $options)
{
return $this->project->getDocument($textDocument->uri)->getFormattedText();
2016-09-06 10:54:34 +00:00
}
2016-10-08 12:59:08 +00:00
/**
* The goto definition request is sent from the client to the server to resolve the definition location of a symbol
* at a given text document position.
*
* @param TextDocumentIdentifier $textDocument The text document
* @param Position $position The position inside the text document
* @return Location|Location[]
2016-10-08 12:59:08 +00:00
*/
public function definition(TextDocumentIdentifier $textDocument, Position $position)
{
$document = $this->project->getDocument($textDocument->uri);
$node = $document->getNodeAtPosition($position);
if ($node === null) {
return [];
2016-10-08 12:59:08 +00:00
}
$def = $document->getDefinitionByNode($node);
if ($def === null) {
return [];
2016-10-08 12:59:08 +00:00
}
return Location::fromNode($def);
2016-10-08 12:59:08 +00:00
}
2016-08-23 09:21:37 +00:00
}