mirror of
https://github.com/denoland/deno.git
synced 2025-01-12 17:09:00 -05:00
refactor(lsp): reduce number of clones (#17254)
This PR optimizes the code in the language server by performing less cloning of data.
This commit is contained in:
parent
2fee8394a9
commit
1a61fe910c
1 changed files with 17 additions and 17 deletions
|
@ -578,8 +578,8 @@ impl Inner {
|
||||||
.and_then(|uri| specifier_to_file_path(uri).ok());
|
.and_then(|uri| specifier_to_file_path(uri).ok());
|
||||||
let root_cert_store = Some(get_root_cert_store(
|
let root_cert_store = Some(get_root_cert_store(
|
||||||
maybe_root_path,
|
maybe_root_path,
|
||||||
workspace_settings.certificate_stores.clone(),
|
workspace_settings.certificate_stores,
|
||||||
workspace_settings.tls_certificate.clone(),
|
workspace_settings.tls_certificate,
|
||||||
)?);
|
)?);
|
||||||
let client = HttpClient::new(
|
let client = HttpClient::new(
|
||||||
root_cert_store,
|
root_cert_store,
|
||||||
|
@ -1011,7 +1011,7 @@ impl Inner {
|
||||||
if self.is_diagnosable(&specifier) {
|
if self.is_diagnosable(&specifier) {
|
||||||
self.refresh_npm_specifiers().await;
|
self.refresh_npm_specifiers().await;
|
||||||
let mut specifiers = self.documents.dependents(&specifier);
|
let mut specifiers = self.documents.dependents(&specifier);
|
||||||
specifiers.push(specifier.clone());
|
specifiers.push(specifier);
|
||||||
self.diagnostics_server.invalidate(&specifiers);
|
self.diagnostics_server.invalidate(&specifiers);
|
||||||
self.send_diagnostics_update();
|
self.send_diagnostics_update();
|
||||||
self.send_testing_update();
|
self.send_testing_update();
|
||||||
|
@ -1550,7 +1550,7 @@ impl Inner {
|
||||||
} else {
|
} else {
|
||||||
combined_code_actions.changes
|
combined_code_actions.changes
|
||||||
};
|
};
|
||||||
let mut code_action = params.clone();
|
let mut code_action = params;
|
||||||
code_action.edit = ts_changes_to_edit(&changes, self).map_err(|err| {
|
code_action.edit = ts_changes_to_edit(&changes, self).map_err(|err| {
|
||||||
error!("Unable to convert changes to edits: {}", err);
|
error!("Unable to convert changes to edits: {}", err);
|
||||||
LspError::internal_error()
|
LspError::internal_error()
|
||||||
|
@ -1558,7 +1558,7 @@ impl Inner {
|
||||||
code_action
|
code_action
|
||||||
} else if kind.as_str().starts_with(CodeActionKind::REFACTOR.as_str()) {
|
} else if kind.as_str().starts_with(CodeActionKind::REFACTOR.as_str()) {
|
||||||
let snapshot = self.snapshot();
|
let snapshot = self.snapshot();
|
||||||
let mut code_action = params.clone();
|
let mut code_action = params;
|
||||||
let action_data: refactor::RefactorCodeActionData = from_value(data)
|
let action_data: refactor::RefactorCodeActionData = from_value(data)
|
||||||
.map_err(|err| {
|
.map_err(|err| {
|
||||||
error!("Unable to decode code action data: {}", err);
|
error!("Unable to decode code action data: {}", err);
|
||||||
|
@ -1569,10 +1569,10 @@ impl Inner {
|
||||||
let start = line_index.offset_tsc(action_data.range.start)?;
|
let start = line_index.offset_tsc(action_data.range.start)?;
|
||||||
let length = line_index.offset_tsc(action_data.range.end)? - start;
|
let length = line_index.offset_tsc(action_data.range.end)? - start;
|
||||||
let req = tsc::RequestMethod::GetEditsForRefactor((
|
let req = tsc::RequestMethod::GetEditsForRefactor((
|
||||||
action_data.specifier.clone(),
|
action_data.specifier,
|
||||||
tsc::TextSpan { start, length },
|
tsc::TextSpan { start, length },
|
||||||
action_data.refactor_name.clone(),
|
action_data.refactor_name,
|
||||||
action_data.action_name.clone(),
|
action_data.action_name,
|
||||||
));
|
));
|
||||||
let refactor_edit_info: tsc::RefactorEditInfo =
|
let refactor_edit_info: tsc::RefactorEditInfo =
|
||||||
self.ts_server.request(snapshot, req).await.map_err(|err| {
|
self.ts_server.request(snapshot, req).await.map_err(|err| {
|
||||||
|
@ -1957,7 +1957,7 @@ impl Inner {
|
||||||
)
|
)
|
||||||
})?;
|
})?;
|
||||||
if let Some(data) = &data.tsc {
|
if let Some(data) = &data.tsc {
|
||||||
let specifier = data.specifier.clone();
|
let specifier = &data.specifier;
|
||||||
let req = tsc::RequestMethod::GetCompletionDetails(data.into());
|
let req = tsc::RequestMethod::GetCompletionDetails(data.into());
|
||||||
let maybe_completion_info: Option<tsc::CompletionEntryDetails> =
|
let maybe_completion_info: Option<tsc::CompletionEntryDetails> =
|
||||||
self.ts_server.request(self.snapshot(), req).await.map_err(
|
self.ts_server.request(self.snapshot(), req).await.map_err(
|
||||||
|
@ -1968,7 +1968,7 @@ impl Inner {
|
||||||
)?;
|
)?;
|
||||||
if let Some(completion_info) = maybe_completion_info {
|
if let Some(completion_info) = maybe_completion_info {
|
||||||
completion_info
|
completion_info
|
||||||
.as_completion_item(¶ms, data, &specifier, self)
|
.as_completion_item(¶ms, data, specifier, self)
|
||||||
.map_err(|err| {
|
.map_err(|err| {
|
||||||
error!(
|
error!(
|
||||||
"Failed to serialize virtual_text_document response: {}",
|
"Failed to serialize virtual_text_document response: {}",
|
||||||
|
@ -2058,7 +2058,7 @@ impl Inner {
|
||||||
let mark = self.performance.mark("folding_range", Some(¶ms));
|
let mark = self.performance.mark("folding_range", Some(¶ms));
|
||||||
let asset_or_doc = self.get_asset_or_document(&specifier)?;
|
let asset_or_doc = self.get_asset_or_document(&specifier)?;
|
||||||
|
|
||||||
let req = tsc::RequestMethod::GetOutliningSpans(specifier.clone());
|
let req = tsc::RequestMethod::GetOutliningSpans(specifier);
|
||||||
let outlining_spans: Vec<tsc::OutliningSpan> = self
|
let outlining_spans: Vec<tsc::OutliningSpan> = self
|
||||||
.ts_server
|
.ts_server
|
||||||
.request(self.snapshot(), req)
|
.request(self.snapshot(), req)
|
||||||
|
@ -2104,7 +2104,7 @@ impl Inner {
|
||||||
let line_index = asset_or_doc.line_index();
|
let line_index = asset_or_doc.line_index();
|
||||||
|
|
||||||
let req = tsc::RequestMethod::ProvideCallHierarchyIncomingCalls((
|
let req = tsc::RequestMethod::ProvideCallHierarchyIncomingCalls((
|
||||||
specifier.clone(),
|
specifier,
|
||||||
line_index.offset_tsc(params.item.selection_range.start)?,
|
line_index.offset_tsc(params.item.selection_range.start)?,
|
||||||
));
|
));
|
||||||
let incoming_calls: Vec<tsc::CallHierarchyIncomingCall> = self
|
let incoming_calls: Vec<tsc::CallHierarchyIncomingCall> = self
|
||||||
|
@ -2150,7 +2150,7 @@ impl Inner {
|
||||||
let line_index = asset_or_doc.line_index();
|
let line_index = asset_or_doc.line_index();
|
||||||
|
|
||||||
let req = tsc::RequestMethod::ProvideCallHierarchyOutgoingCalls((
|
let req = tsc::RequestMethod::ProvideCallHierarchyOutgoingCalls((
|
||||||
specifier.clone(),
|
specifier,
|
||||||
line_index.offset_tsc(params.item.selection_range.start)?,
|
line_index.offset_tsc(params.item.selection_range.start)?,
|
||||||
));
|
));
|
||||||
let outgoing_calls: Vec<tsc::CallHierarchyOutgoingCall> = self
|
let outgoing_calls: Vec<tsc::CallHierarchyOutgoingCall> = self
|
||||||
|
@ -2201,7 +2201,7 @@ impl Inner {
|
||||||
let line_index = asset_or_doc.line_index();
|
let line_index = asset_or_doc.line_index();
|
||||||
|
|
||||||
let req = tsc::RequestMethod::PrepareCallHierarchy((
|
let req = tsc::RequestMethod::PrepareCallHierarchy((
|
||||||
specifier.clone(),
|
specifier,
|
||||||
line_index.offset_tsc(params.text_document_position_params.position)?,
|
line_index.offset_tsc(params.text_document_position_params.position)?,
|
||||||
));
|
));
|
||||||
let maybe_one_or_many: Option<tsc::OneOrMany<tsc::CallHierarchyItem>> =
|
let maybe_one_or_many: Option<tsc::OneOrMany<tsc::CallHierarchyItem>> =
|
||||||
|
@ -2355,7 +2355,7 @@ impl Inner {
|
||||||
let line_index = asset_or_doc.line_index();
|
let line_index = asset_or_doc.line_index();
|
||||||
|
|
||||||
let req = tsc::RequestMethod::GetEncodedSemanticClassifications((
|
let req = tsc::RequestMethod::GetEncodedSemanticClassifications((
|
||||||
specifier.clone(),
|
specifier,
|
||||||
tsc::TextSpan {
|
tsc::TextSpan {
|
||||||
start: 0,
|
start: 0,
|
||||||
length: line_index.text_content_length_utf16().into(),
|
length: line_index.text_content_length_utf16().into(),
|
||||||
|
@ -2401,7 +2401,7 @@ impl Inner {
|
||||||
let start = line_index.offset_tsc(params.range.start)?;
|
let start = line_index.offset_tsc(params.range.start)?;
|
||||||
let length = line_index.offset_tsc(params.range.end)? - start;
|
let length = line_index.offset_tsc(params.range.end)? - start;
|
||||||
let req = tsc::RequestMethod::GetEncodedSemanticClassifications((
|
let req = tsc::RequestMethod::GetEncodedSemanticClassifications((
|
||||||
specifier.clone(),
|
specifier,
|
||||||
tsc::TextSpan { start, length },
|
tsc::TextSpan { start, length },
|
||||||
));
|
));
|
||||||
let semantic_classification: tsc::Classifications = self
|
let semantic_classification: tsc::Classifications = self
|
||||||
|
@ -3025,7 +3025,7 @@ impl Inner {
|
||||||
LspError::internal_error()
|
LspError::internal_error()
|
||||||
})?;
|
})?;
|
||||||
let req = tsc::RequestMethod::ProvideInlayHints((
|
let req = tsc::RequestMethod::ProvideInlayHints((
|
||||||
specifier.clone(),
|
specifier,
|
||||||
range,
|
range,
|
||||||
(&workspace_settings).into(),
|
(&workspace_settings).into(),
|
||||||
));
|
));
|
||||||
|
|
Loading…
Reference in a new issue