lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <CAJ-ks9=525PETbRGuZn=rv=H9AC=Sjgn47DSGxrKLi=0HxBmfQ@mail.gmail.com>
Date: Sun, 4 Jan 2026 17:59:35 -0500
From: Tamir Duberstein <tamird@...il.com>
To: Gary Guo <gary@...yguo.net>
Cc: Miguel Ojeda <ojeda@...nel.org>, Boqun Feng <boqun.feng@...il.com>, 
	Björn Roy Baron <bjorn3_gh@...tonmail.com>, 
	Benno Lossin <lossin@...nel.org>, Andreas Hindborg <a.hindborg@...nel.org>, 
	Alice Ryhl <aliceryhl@...gle.com>, Trevor Gross <tmgross@...ch.edu>, 
	Danilo Krummrich <dakr@...nel.org>, Fiona Behrens <me@...enk.dev>, 
	Guilherme Giacomo Simoes <trintaeoitogc@...il.com>, José Expósito <jose.exposito89@...il.com>, 
	rust-for-linux@...r.kernel.org, David Gow <davidgow@...gle.com>, 
	linux-kernel@...r.kernel.org
Subject: Re: [PATCH 07/11] rust: macros: convert `concat_idents!` to use `syn`

On Thu, Dec 11, 2025 at 2:30 PM Gary Guo <gary@...nel.org> wrote:
>
> From: Gary Guo <gary@...yguo.net>
>
> This eliminates the need for `expect_punct` helper.
>
> Signed-off-by: Gary Guo <gary@...yguo.net>

Reviewed-by: Tamir Duberstein <tamird@...il.com>

> ---
>  rust/macros/concat_idents.rs | 39 ++++++++++++++++++++++++------------
>  rust/macros/helpers.rs       | 14 +------------
>  rust/macros/lib.rs           |  4 ++--
>  3 files changed, 29 insertions(+), 28 deletions(-)
>
> diff --git a/rust/macros/concat_idents.rs b/rust/macros/concat_idents.rs
> index 12cb231c3d715..47b6add378d2c 100644
> --- a/rust/macros/concat_idents.rs
> +++ b/rust/macros/concat_idents.rs
> @@ -1,23 +1,36 @@
>  // SPDX-License-Identifier: GPL-2.0
>
> -use proc_macro2::{token_stream, Ident, TokenStream, TokenTree};
> +use proc_macro2::{
> +    Ident,
> +    TokenStream,
> +    TokenTree, //
> +};
> +use syn::{
> +    parse::{
> +        Parse,
> +        ParseStream, //
> +    },
> +    Result,
> +    Token, //
> +};
>
> -use crate::helpers::expect_punct;
> +pub(crate) struct Input {
> +    a: Ident,
> +    _comma: Token![,],
> +    b: Ident,
> +}
>
> -fn expect_ident(it: &mut token_stream::IntoIter) -> Ident {
> -    if let Some(TokenTree::Ident(ident)) = it.next() {
> -        ident
> -    } else {
> -        panic!("Expected Ident")
> +impl Parse for Input {
> +    fn parse(input: ParseStream<'_>) -> Result<Self> {
> +        Ok(Self {
> +            a: input.parse()?,
> +            _comma: input.parse()?,
> +            b: input.parse()?,
> +        })
>      }
>  }
>
> -pub(crate) fn concat_idents(ts: TokenStream) -> TokenStream {
> -    let mut it = ts.into_iter();
> -    let a = expect_ident(&mut it);
> -    assert_eq!(expect_punct(&mut it), ',');
> -    let b = expect_ident(&mut it);
> -    assert!(it.next().is_none(), "only two idents can be concatenated");
> +pub(crate) fn concat_idents(Input { a, b, .. }: Input) -> TokenStream {
>      let res = Ident::new(&format!("{a}{b}"), b.span());
>      TokenStream::from_iter([TokenTree::Ident(res)])
>  }
> diff --git a/rust/macros/helpers.rs b/rust/macros/helpers.rs
> index 754c827cc21e1..adfa60d8f42d8 100644
> --- a/rust/macros/helpers.rs
> +++ b/rust/macros/helpers.rs
> @@ -1,10 +1,6 @@
>  // SPDX-License-Identifier: GPL-2.0
>
> -use proc_macro2::{
> -    token_stream,
> -    TokenStream,
> -    TokenTree, //
> -};
> +use proc_macro2::TokenStream;
>  use quote::ToTokens;
>  use syn::{
>      parse::{
> @@ -16,14 +12,6 @@
>      Result, //
>  };
>
> -pub(crate) fn expect_punct(it: &mut token_stream::IntoIter) -> char {
> -    if let TokenTree::Punct(punct) = it.next().expect("Reached end of token stream for Punct") {
> -        punct.as_char()
> -    } else {
> -        panic!("Expected Punct");
> -    }
> -}
> -
>  /// A string literal that is required to have ASCII value only.
>  pub(crate) struct AsciiLitStr(LitStr);
>
> diff --git a/rust/macros/lib.rs b/rust/macros/lib.rs
> index 870a42d41ac91..bb2dfd4a4dafc 100644
> --- a/rust/macros/lib.rs
> +++ b/rust/macros/lib.rs
> @@ -283,8 +283,8 @@ pub fn fmt(input: TokenStream) -> TokenStream {
>  /// assert_eq!(BR_OK, binder_driver_return_protocol_BR_OK);
>  /// ```
>  #[proc_macro]
> -pub fn concat_idents(ts: TokenStream) -> TokenStream {
> -    concat_idents::concat_idents(ts.into()).into()
> +pub fn concat_idents(input: TokenStream) -> TokenStream {
> +    concat_idents::concat_idents(parse_macro_input!(input)).into()
>  }
>
>  /// Paste identifiers together.
> --
> 2.51.2
>

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ