From 9005d849543fd1660a0ecf42981011a7fbaccdbc Mon Sep 17 00:00:00 2001 From: David Tolnay Date: Sat, 19 Oct 2024 22:23:21 -0700 Subject: [PATCH] Duplicate unparsed input paragraph from parse2 to parse and parse_str https://github.com/dtolnay/syn/issues/1723 --- src/lib.rs | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index 0da98efd5e..54b4ee21b7 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -888,6 +888,9 @@ pub mod __private; /// `proc_macro2::TokenStream`, use [`syn::parse2`] instead. /// /// [`syn::parse2`]: parse2 +/// +/// This function enforces that the input is fully parsed. If there are any +/// unparsed tokens at the end of the stream, an error is returned. #[cfg(all(feature = "parsing", feature = "proc-macro"))] #[cfg_attr(docsrs, doc(cfg(all(feature = "parsing", feature = "proc-macro"))))] pub fn parse(tokens: proc_macro::TokenStream) -> Result { @@ -896,9 +899,6 @@ pub fn parse(tokens: proc_macro::TokenStream) -> Result { /// Parse a proc-macro2 token stream into the chosen syntax tree node. /// -/// This function enforces that the input is fully parsed. If there are any -/// unparsed tokens at the end of the stream, an error is returned. -/// /// This function parses a `proc_macro2::TokenStream` which is commonly useful /// when the input comes from a node of the Syn syntax tree, for example the /// body tokens of a [`Macro`] node. When in a procedural macro parsing the @@ -906,6 +906,9 @@ pub fn parse(tokens: proc_macro::TokenStream) -> Result { /// instead. /// /// [`syn::parse`]: parse() +/// +/// This function enforces that the input is fully parsed. If there are any +/// unparsed tokens at the end of the stream, an error is returned. #[cfg(feature = "parsing")] #[cfg_attr(docsrs, doc(cfg(feature = "parsing")))] pub fn parse2(tokens: proc_macro2::TokenStream) -> Result { @@ -914,6 +917,9 @@ pub fn parse2(tokens: proc_macro2::TokenStream) -> Result { /// Parse a string of Rust code into the chosen syntax tree node. /// +/// This function enforces that the input is fully parsed. If there are any +/// unparsed tokens at the end of the stream, an error is returned. +/// /// # Hygiene /// /// Every span in the resulting syntax tree will be set to resolve at the macro