Macro syn::braced [−][src]
macro_rules! braced { ($content:ident in $cursor:expr) => { ... }; }
Expand description
Parse a set of curly braces and expose their content to subsequent parsers.
Example
use syn::{braced, token, Ident, Result, Token, Type}; use syn::parse::{Parse, ParseStream}; use syn::punctuated::Punctuated; // Parse a simplified struct syntax like: // // struct S { // a: A, // b: B, // } struct Struct { struct_token: Token![struct], ident: Ident, brace_token: token::Brace, fields: Punctuated<Field, Token![,]>, } struct Field { name: Ident, colon_token: Token![:], ty: Type, } impl Parse for Struct { fn parse(input: ParseStream) -> Result<Self> { let content; Ok(Struct { struct_token: input.parse()?, ident: input.parse()?, brace_token: braced!(content in input), fields: content.parse_terminated(Field::parse)?, }) } } impl Parse for Field { fn parse(input: ParseStream) -> Result<Self> { Ok(Field { name: input.parse()?, colon_token: input.parse()?, ty: input.parse()?, }) } }