mirror of
https://github.com/nushell/nushell
synced 2025-01-28 04:45:18 +00:00
Make ast::Call::span()
and arguments_span()
more robust (#13412)
# Description Trying to help @amtoine out here - the spans calculated by `ast::Call` by `span()` and `argument_span()` are suspicious and are not properly guarding against `end` that might be before `start`. Just using `Span::merge()` / `merge_many()` instead to try to make the behaviour as simple and consistent as possible. Hopefully then even if the arguments have some crazy spans, we don't have spans that are just totally invalid. # Tests + Formatting I did check that everything passes with this.
This commit is contained in:
parent
4665323bb4
commit
aa9a42776b
1 changed files with 6 additions and 32 deletions
|
@ -110,17 +110,11 @@ impl Call {
|
||||||
/// If there are one or more arguments the span encompasses the start of the first argument to
|
/// If there are one or more arguments the span encompasses the start of the first argument to
|
||||||
/// end of the last argument
|
/// end of the last argument
|
||||||
pub fn arguments_span(&self) -> Span {
|
pub fn arguments_span(&self) -> Span {
|
||||||
let past = self.head.past();
|
if self.arguments.is_empty() {
|
||||||
|
self.head.past()
|
||||||
let start = self
|
} else {
|
||||||
.arguments
|
Span::merge_many(self.arguments.iter().map(|a| a.span()))
|
||||||
.first()
|
}
|
||||||
.map(|a| a.span())
|
|
||||||
.unwrap_or(past)
|
|
||||||
.start;
|
|
||||||
let end = self.arguments.last().map(|a| a.span()).unwrap_or(past).end;
|
|
||||||
|
|
||||||
Span::new(start, end)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn named_iter(
|
pub fn named_iter(
|
||||||
|
@ -341,27 +335,7 @@ impl Call {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn span(&self) -> Span {
|
pub fn span(&self) -> Span {
|
||||||
let mut span = self.head;
|
self.head.merge(self.arguments_span())
|
||||||
|
|
||||||
for positional in self.positional_iter() {
|
|
||||||
if positional.span.end > span.end {
|
|
||||||
span.end = positional.span.end;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (named, _, val) in self.named_iter() {
|
|
||||||
if named.span.end > span.end {
|
|
||||||
span.end = named.span.end;
|
|
||||||
}
|
|
||||||
|
|
||||||
if let Some(val) = &val {
|
|
||||||
if val.span.end > span.end {
|
|
||||||
span.end = val.span.end;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
span
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue