Auto merge of #13697 - jonas-schievink:version-inlay-hint-resolve-data, r=jonas-schievink
internal: Version the inlay hint resolve data cc https://github.com/rust-lang/rust-analyzer/issues/13657 cc https://github.com/rust-lang/rust-analyzer/issues/13372 cc https://github.com/rust-lang/rust-analyzer/issues/13170 This will make us log an error and return the unmodified inlay hints when the client attempts to resolve inlay hints in a file that has since been modified.
This commit is contained in:
commit
398a71affb
@ -67,7 +67,15 @@ pub(crate) fn file_range(
|
||||
text_document_identifier: lsp_types::TextDocumentIdentifier,
|
||||
range: lsp_types::Range,
|
||||
) -> Result<FileRange> {
|
||||
let file_id = file_id(snap, &text_document_identifier.uri)?;
|
||||
file_range_uri(snap, &text_document_identifier.uri, range)
|
||||
}
|
||||
|
||||
pub(crate) fn file_range_uri(
|
||||
snap: &GlobalStateSnapshot,
|
||||
document: &lsp_types::Url,
|
||||
range: lsp_types::Range,
|
||||
) -> Result<FileRange> {
|
||||
let file_id = file_id(snap, document)?;
|
||||
let line_index = snap.file_line_index(file_id)?;
|
||||
let range = text_range(&line_index, range)?;
|
||||
Ok(FileRange { file_id, range })
|
||||
|
@ -29,6 +29,7 @@ use project_model::{ManifestPath, ProjectWorkspace, TargetKind};
|
||||
use serde_json::json;
|
||||
use stdx::{format_to, never};
|
||||
use syntax::{algo, ast, AstNode, TextRange, TextSize};
|
||||
use tracing::error;
|
||||
use vfs::AbsPathBuf;
|
||||
|
||||
use crate::{
|
||||
@ -1372,9 +1373,26 @@ pub(crate) fn handle_inlay_hints_resolve(
|
||||
|
||||
let resolve_data: lsp_ext::InlayHintResolveData = serde_json::from_value(data)?;
|
||||
|
||||
let file_range = from_proto::file_range(
|
||||
match snap.url_file_version(&resolve_data.text_document.uri) {
|
||||
Some(version) if version == resolve_data.text_document.version => {}
|
||||
Some(version) => {
|
||||
error!(
|
||||
"attempted inlayHints/resolve of '{}' at version {} while server version is {}",
|
||||
resolve_data.text_document.uri, resolve_data.text_document.version, version,
|
||||
);
|
||||
return Ok(hint);
|
||||
}
|
||||
None => {
|
||||
error!(
|
||||
"attempted inlayHints/resolve of unknown file '{}' at version {}",
|
||||
resolve_data.text_document.uri, resolve_data.text_document.version,
|
||||
);
|
||||
return Ok(hint);
|
||||
}
|
||||
}
|
||||
let file_range = from_proto::file_range_uri(
|
||||
&snap,
|
||||
resolve_data.text_document,
|
||||
&resolve_data.text_document.uri,
|
||||
match resolve_data.position {
|
||||
PositionOrRange::Position(pos) => Range::new(pos, pos),
|
||||
PositionOrRange::Range(range) => range,
|
||||
|
@ -3,11 +3,11 @@
|
||||
use std::{collections::HashMap, path::PathBuf};
|
||||
|
||||
use lsp_types::request::Request;
|
||||
use lsp_types::PositionEncodingKind;
|
||||
use lsp_types::{
|
||||
notification::Notification, CodeActionKind, DocumentOnTypeFormattingParams,
|
||||
PartialResultParams, Position, Range, TextDocumentIdentifier, WorkDoneProgressParams,
|
||||
};
|
||||
use lsp_types::{PositionEncodingKind, VersionedTextDocumentIdentifier};
|
||||
use serde::{Deserialize, Serialize};
|
||||
|
||||
pub enum AnalyzerStatus {}
|
||||
@ -550,7 +550,7 @@ pub struct CompletionResolveData {
|
||||
|
||||
#[derive(Debug, Serialize, Deserialize)]
|
||||
pub struct InlayHintResolveData {
|
||||
pub text_document: TextDocumentIdentifier,
|
||||
pub text_document: VersionedTextDocumentIdentifier,
|
||||
pub position: PositionOrRange,
|
||||
}
|
||||
|
||||
|
@ -492,7 +492,10 @@ pub(crate) fn inlay_hint(
|
||||
let uri = url(snap, file_id);
|
||||
let line_index = snap.file_line_index(file_id).ok()?;
|
||||
|
||||
let text_document = lsp_types::TextDocumentIdentifier { uri };
|
||||
let text_document = lsp_types::VersionedTextDocumentIdentifier {
|
||||
version: snap.url_file_version(&uri)?,
|
||||
uri,
|
||||
};
|
||||
to_value(lsp_ext::InlayHintResolveData {
|
||||
text_document,
|
||||
position: lsp_ext::PositionOrRange::Position(position(&line_index, offset)),
|
||||
@ -501,7 +504,10 @@ pub(crate) fn inlay_hint(
|
||||
}
|
||||
Some(ide::InlayTooltip::HoverRanged(file_id, text_range)) => {
|
||||
let uri = url(snap, file_id);
|
||||
let text_document = lsp_types::TextDocumentIdentifier { uri };
|
||||
let text_document = lsp_types::VersionedTextDocumentIdentifier {
|
||||
version: snap.url_file_version(&uri)?,
|
||||
uri,
|
||||
};
|
||||
let line_index = snap.file_line_index(file_id).ok()?;
|
||||
to_value(lsp_ext::InlayHintResolveData {
|
||||
text_document,
|
||||
|
@ -1,5 +1,5 @@
|
||||
<!---
|
||||
lsp_ext.rs hash: 62068e53ac202dc8
|
||||
lsp_ext.rs hash: 61fe425627f9baaa
|
||||
|
||||
If you need to change the above hash to make the test pass, please check if you
|
||||
need to adjust this doc as well and ping this issue:
|
||||
|
Loading…
x
Reference in New Issue
Block a user