Skip to content

Commit

Permalink
Merge pull request #1654 from dtolnay/assocconst
Browse files Browse the repository at this point in the history
Add legalization for expressions inside AssocConst
  • Loading branch information
dtolnay authored May 15, 2024
2 parents 816a333 + e82bbb5 commit 1d218f9
Showing 1 changed file with 28 additions and 24 deletions.
52 changes: 28 additions & 24 deletions src/path.rs
Original file line number Diff line number Diff line change
Expand Up @@ -741,36 +741,40 @@ pub(crate) mod printing {
match self {
GenericArgument::Lifetime(lt) => lt.to_tokens(tokens),
GenericArgument::Type(ty) => ty.to_tokens(tokens),
GenericArgument::Const(expr) => match expr {
Expr::Lit(expr) => expr.to_tokens(tokens),

Expr::Path(expr)
if expr.attrs.is_empty()
&& expr.qself.is_none()
&& expr.path.get_ident().is_some() =>
{
expr.to_tokens(tokens);
}

#[cfg(feature = "full")]
Expr::Block(expr) => expr.to_tokens(tokens),

#[cfg(not(feature = "full"))]
Expr::Verbatim(expr) => expr.to_tokens(tokens),

// ERROR CORRECTION: Add braces to make sure that the
// generated code is valid.
_ => token::Brace::default().surround(tokens, |tokens| {
expr.to_tokens(tokens);
}),
},
GenericArgument::Const(expr) => print_const_argument(expr, tokens),
GenericArgument::AssocType(assoc) => assoc.to_tokens(tokens),
GenericArgument::AssocConst(assoc) => assoc.to_tokens(tokens),
GenericArgument::Constraint(constraint) => constraint.to_tokens(tokens),
}
}
}

fn print_const_argument(expr: &Expr, tokens: &mut TokenStream) {
match expr {
Expr::Lit(expr) => expr.to_tokens(tokens),

Expr::Path(expr)
if expr.attrs.is_empty()
&& expr.qself.is_none()
&& expr.path.get_ident().is_some() =>
{
expr.to_tokens(tokens);
}

#[cfg(feature = "full")]
Expr::Block(expr) => expr.to_tokens(tokens),

#[cfg(not(feature = "full"))]
Expr::Verbatim(expr) => expr.to_tokens(tokens),

// ERROR CORRECTION: Add braces to make sure that the
// generated code is valid.
_ => token::Brace::default().surround(tokens, |tokens| {
expr.to_tokens(tokens);
}),
}
}

#[cfg_attr(doc_cfg, doc(cfg(feature = "printing")))]
impl ToTokens for AngleBracketedGenericArguments {
fn to_tokens(&self, tokens: &mut TokenStream) {
Expand Down Expand Up @@ -830,7 +834,7 @@ pub(crate) mod printing {
self.ident.to_tokens(tokens);
self.generics.to_tokens(tokens);
self.eq_token.to_tokens(tokens);
self.value.to_tokens(tokens);
print_const_argument(&self.value, tokens);
}
}

Expand Down

0 comments on commit 1d218f9

Please sign in to comment.