Unnamed repository; edit this file 'description' to name the repository.
Auto merge of #13573 - Veykril:invalid-file-range, r=Veykril
internal: error instead of panic on invalid file range Fixes the panic in https://github.com/rust-lang/rust-analyzer/issues/13170
bors 2022-11-07
parent 0aa0da9 · parent 1cb6ab8 · commit b8b1951
-rw-r--r--crates/rust-analyzer/src/from_proto.rs6
1 files changed, 4 insertions, 2 deletions
diff --git a/crates/rust-analyzer/src/from_proto.rs b/crates/rust-analyzer/src/from_proto.rs
index 936957bab4..dd433b0f4d 100644
--- a/crates/rust-analyzer/src/from_proto.rs
+++ b/crates/rust-analyzer/src/from_proto.rs
@@ -42,8 +42,10 @@ pub(crate) fn offset(line_index: &LineIndex, position: lsp_types::Position) -> R
pub(crate) fn text_range(line_index: &LineIndex, range: lsp_types::Range) -> Result<TextRange> {
let start = offset(line_index, range.start)?;
let end = offset(line_index, range.end)?;
- let text_range = TextRange::new(start, end);
- Ok(text_range)
+ match end < start {
+ true => Err(format_err!("Invalid Range").into()),
+ false => Ok(TextRange::new(start, end)),
+ }
}
pub(crate) fn file_id(snap: &GlobalStateSnapshot, url: &lsp_types::Url) -> Result<FileId> {