mirror of
https://github.com/dtolnay/thiserror.git
synced 2025-04-04 21:37:57 +03:00
Merge pull request #399 from dtolnay/respan
Fix spans on macro-generated bindings and format variables
This commit is contained in:
commit
a7de3ab22d
3 changed files with 40 additions and 8 deletions
|
@ -107,12 +107,14 @@ impl Display<'_> {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
infinite_recursive |= member == *"self" && bound == Trait::Display;
|
infinite_recursive |= member == *"self" && bound == Trait::Display;
|
||||||
if let Some(&field) = member_index.get(&member) {
|
let field = match member_index.get(&member) {
|
||||||
implied_bounds.insert((field, bound));
|
Some(&field) => field,
|
||||||
} else {
|
None => {
|
||||||
out += &member.to_string();
|
out += &member.to_string();
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
};
|
||||||
|
implied_bounds.insert((field, bound));
|
||||||
let formatvar_prefix = if bonus_display {
|
let formatvar_prefix = if bonus_display {
|
||||||
"__display"
|
"__display"
|
||||||
} else if bound == Trait::Pointer {
|
} else if bound == Trait::Pointer {
|
||||||
|
@ -129,15 +131,17 @@ impl Display<'_> {
|
||||||
while user_named_args.contains(&formatvar) {
|
while user_named_args.contains(&formatvar) {
|
||||||
formatvar = IdentUnraw::new(format_ident!("_{}", formatvar.to_string()));
|
formatvar = IdentUnraw::new(format_ident!("_{}", formatvar.to_string()));
|
||||||
}
|
}
|
||||||
|
formatvar.set_span(span);
|
||||||
out += &formatvar.to_string();
|
out += &formatvar.to_string();
|
||||||
if !macro_named_args.insert(formatvar.clone()) {
|
if !macro_named_args.insert(formatvar.clone()) {
|
||||||
// Already added to bindings by a previous use.
|
// Already added to bindings by a previous use.
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
let binding_value = match &member {
|
let mut binding_value = match &member {
|
||||||
MemberUnraw::Unnamed(index) => format_ident!("_{}", index),
|
MemberUnraw::Unnamed(index) => format_ident!("_{}", index),
|
||||||
MemberUnraw::Named(ident) => ident.to_local(),
|
MemberUnraw::Named(ident) => ident.to_local(),
|
||||||
};
|
};
|
||||||
|
binding_value.set_span(span.resolved_at(fields[field].member.span()));
|
||||||
let wrapped_binding_value = if bonus_display {
|
let wrapped_binding_value = if bonus_display {
|
||||||
quote_spanned!(span=> #binding_value.as_display())
|
quote_spanned!(span=> #binding_value.as_display())
|
||||||
} else if bound == Trait::Pointer {
|
} else if bound == Trait::Pointer {
|
||||||
|
|
|
@ -28,6 +28,10 @@ impl IdentUnraw {
|
||||||
}
|
}
|
||||||
unraw
|
unraw
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn set_span(&mut self, span: Span) {
|
||||||
|
self.0.set_span(span);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Display for IdentUnraw {
|
impl Display for IdentUnraw {
|
||||||
|
|
|
@ -266,7 +266,7 @@ fn test_pointer() {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_macro_rules() {
|
fn test_macro_rules_variant_from_call_site() {
|
||||||
// Regression test for https://github.com/dtolnay/thiserror/issues/86
|
// Regression test for https://github.com/dtolnay/thiserror/issues/86
|
||||||
|
|
||||||
macro_rules! decl_error {
|
macro_rules! decl_error {
|
||||||
|
@ -291,6 +291,30 @@ fn test_macro_rules() {
|
||||||
assert("0", Error1::Repro(0));
|
assert("0", Error1::Repro(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_macro_rules_message_from_call_site() {
|
||||||
|
// Regression test for https://github.com/dtolnay/thiserror/issues/398
|
||||||
|
|
||||||
|
macro_rules! decl_error {
|
||||||
|
($($errors:tt)*) => {
|
||||||
|
#[derive(Error, Debug)]
|
||||||
|
pub enum Error {
|
||||||
|
$($errors)*
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
decl_error! {
|
||||||
|
#[error("{0}")]
|
||||||
|
Unnamed(u8),
|
||||||
|
#[error("{x}")]
|
||||||
|
Named { x: u8 },
|
||||||
|
}
|
||||||
|
|
||||||
|
assert("0", Error::Unnamed(0));
|
||||||
|
assert("0", Error::Named { x: 0 });
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_raw() {
|
fn test_raw() {
|
||||||
#[derive(Error, Debug)]
|
#[derive(Error, Debug)]
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue