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:
Devyn Cairns 2024-07-19 05:12:19 -07:00 committed by GitHub
parent 4665323bb4
commit aa9a42776b
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -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
} }
} }