From 2d7f49c79c4a1ae4734960eb82e0e04509e3bd27 Mon Sep 17 00:00:00 2001 From: Arthur Carcano Date: Fri, 29 Sep 2023 16:39:05 +0200 Subject: [PATCH 1/5] fix: Recipes had drifted from the implementation and weren't compiling This 1. Adds the recipes to the doctests so that they don't drift anymore 2. Fixes them --- doc/nom_recipes.md | 37 +++++++++++++++++++++++-------------- src/lib.rs | 4 ++++ 2 files changed, 27 insertions(+), 14 deletions(-) diff --git a/doc/nom_recipes.md b/doc/nom_recipes.md index 1a767734a..4a14df32b 100644 --- a/doc/nom_recipes.md +++ b/doc/nom_recipes.md @@ -35,9 +35,9 @@ use nom::{ /// A combinator that takes a parser `inner` and produces a parser that also consumes both leading and /// trailing whitespace, returning the output of `inner`. -fn ws<'a, F, O, E: ParseError<&'a str>>(inner: F) -> impl FnMut(&'a str) -> IResult<&'a str, O, E> +fn ws<'a, F, O, E: ParseError<&'a str>>(inner: F) -> impl Parser<&'a str> where - F: Parser<&'a str, O, E>, + F: Parser<&'a str>, { delimited( multispace0, @@ -62,6 +62,7 @@ output of `()`. ```rust use nom::{ IResult, + Parser, error::ParseError, combinator::value, sequence::pair, @@ -74,7 +75,7 @@ pub fn peol_comment<'a, E: ParseError<&'a str>>(i: &'a str) -> IResult<&'a str, value( (), // Output is thrown away. pair(char('%'), is_not("\n\r")) - )(i) + ).parse(i) } ``` @@ -86,6 +87,7 @@ and does not handle nested comments. ```rust use nom::{ IResult, + Parser, error::ParseError, combinator::value, bytes::complete::{tag, take_until}, @@ -99,7 +101,7 @@ pub fn pinline_comment<'a, E: ParseError<&'a str>>(i: &'a str) -> IResult<&'a st take_until("*)"), tag("*)") ) - )(i) + ).parse(i) } ``` @@ -113,6 +115,7 @@ letters and numbers may be parsed like this: ```rust use nom::{ IResult, + Parser, branch::alt, multi::many0_count, combinator::recognize, @@ -127,7 +130,7 @@ pub fn identifier(input: &str) -> IResult<&str, &str> { alt((alpha1, tag("_"))), many0_count(alt((alphanumeric1, tag("_")))) ) - )(input) + ).parse(input) } ``` @@ -164,6 +167,7 @@ The parser outputs the string slice of the digits without the leading `0x`/`0X`. ```rust use nom::{ IResult, + Parser, branch::alt, multi::{many0, many1}, combinator::recognize, @@ -180,7 +184,7 @@ fn hexadecimal(input: &str) -> IResult<&str, &str> { // <'a, E: ParseError<&'a s terminated(one_of("0123456789abcdefABCDEF"), many0(char('_'))) ) ) - )(input) + ).parse(input) } ``` @@ -189,6 +193,7 @@ If you want it to return the integer value instead, use map: ```rust use nom::{ IResult, + Parser, branch::alt, multi::{many0, many1}, combinator::{map_res, recognize}, @@ -208,7 +213,7 @@ fn hexadecimal_value(input: &str) -> IResult<&str, i64> { ) ), |out: &str| i64::from_str_radix(&str::replace(&out, "_", ""), 16) - )(input) + ).parse(input) } ``` @@ -217,6 +222,7 @@ fn hexadecimal_value(input: &str) -> IResult<&str, i64> { ```rust use nom::{ IResult, + Parser, branch::alt, multi::{many0, many1}, combinator::recognize, @@ -233,7 +239,7 @@ fn octal(input: &str) -> IResult<&str, &str> { terminated(one_of("01234567"), many0(char('_'))) ) ) - )(input) + ).parse(input) } ``` @@ -242,6 +248,7 @@ fn octal(input: &str) -> IResult<&str, &str> { ```rust use nom::{ IResult, + Parser, branch::alt, multi::{many0, many1}, combinator::recognize, @@ -258,7 +265,7 @@ fn binary(input: &str) -> IResult<&str, &str> { terminated(one_of("01"), many0(char('_'))) ) ) - )(input) + ).parse(input) } ``` @@ -267,6 +274,7 @@ fn binary(input: &str) -> IResult<&str, &str> { ```rust use nom::{ IResult, + Parser, multi::{many0, many1}, combinator::recognize, sequence::terminated, @@ -278,7 +286,7 @@ fn decimal(input: &str) -> IResult<&str, &str> { many1( terminated(one_of("0123456789"), many0(char('_'))) ) - )(input) + ).parse(input) } ``` @@ -289,6 +297,7 @@ The following is adapted from [the Python parser by Valentin Lorentz (ProgVal)]( ```rust use nom::{ IResult, + Parser, branch::alt, multi::{many0, many1}, combinator::{opt, recognize}, @@ -331,7 +340,7 @@ fn float(input: &str) -> IResult<&str, &str> { opt(decimal) ) ) - ))(input) + )).parse(input) } fn decimal(input: &str) -> IResult<&str, &str> { @@ -339,7 +348,7 @@ fn decimal(input: &str) -> IResult<&str, &str> { many1( terminated(one_of("0123456789"), many0(char('_'))) ) - )(input) + ).parse(input) } ``` @@ -350,14 +359,14 @@ a common interface to parse from a string. ```rust use nom::{ - IResult, Finish, error::Error, + IResult, Parser, Finish, error::Error, bytes::complete::{tag, take_while}, }; use std::str::FromStr; // will recognize the name in "Hello, name!" fn parse_name(input: &str) -> IResult<&str, &str> { - let (i, _) = tag("Hello, ")(input)?; + let (i, _) = tag("Hello, ").parse(input)?; let (i, name) = take_while(|c:char| c.is_alphabetic())(i)?; let (i, _) = tag("!")(i)?; diff --git a/src/lib.rs b/src/lib.rs index a1c1ac890..b1aef1433 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -466,3 +466,7 @@ pub mod number; #[cfg(feature = "docsrs")] #[cfg_attr(feature = "docsrs", cfg_attr(feature = "docsrs", doc = include_str!("../doc/nom_recipes.md")))] pub mod recipes {} + +#[cfg(doctest)] +#[doc = include_str!("../doc/nom_recipes.md")] +pub mod recipes {} From 40f29cd2c26d73520d14a0c3c0e3ed6664a5a9bb Mon Sep 17 00:00:00 2001 From: Geoffroy Couprie Date: Sat, 21 Oct 2023 17:39:51 +0200 Subject: [PATCH 2/5] more explicit title to appear in docs --- doc/nom_recipes.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/doc/nom_recipes.md b/doc/nom_recipes.md index 4a14df32b..122f49d59 100644 --- a/doc/nom_recipes.md +++ b/doc/nom_recipes.md @@ -1,4 +1,4 @@ -# Nom Recipes +# Common recipes to build nom parsers These are short recipes for accomplishing common tasks with nom. From 3b2bb0a67ffd2e5dcca69ede408b0c28a39857cf Mon Sep 17 00:00:00 2001 From: Geoffroy Couprie Date: Sat, 21 Oct 2023 17:40:04 +0200 Subject: [PATCH 3/5] merge imports --- src/lib.rs | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index b1aef1433..65b6f9e64 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -377,7 +377,6 @@ //! check out the [recipes]! #![cfg_attr(not(feature = "std"), no_std)] #![cfg_attr(feature = "docsrs", feature(doc_cfg))] -#![cfg_attr(feature = "docsrs", feature(extended_key_value_attributes))] #![allow(clippy::doc_markdown)] #![deny(missing_docs)] #[cfg_attr(nightly, warn(rustdoc::missing_doc_code_examples))] @@ -463,10 +462,7 @@ mod str; pub mod number; -#[cfg(feature = "docsrs")] +#[cfg(any(doc, doctest, feature = "docsrs"))] #[cfg_attr(feature = "docsrs", cfg_attr(feature = "docsrs", doc = include_str!("../doc/nom_recipes.md")))] -pub mod recipes {} - -#[cfg(doctest)] -#[doc = include_str!("../doc/nom_recipes.md")] +#[cfg_attr(any(doc, doctest, feature = "docsrs"), doc = include_str!("../doc/nom_recipes.md"))] pub mod recipes {} From 741d5b94f17f2adc62173273160c4c01323079b7 Mon Sep 17 00:00:00 2001 From: Geoffroy Couprie Date: Sat, 21 Oct 2023 17:49:55 +0200 Subject: [PATCH 4/5] fix feature usage --- src/lib.rs | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index 65b6f9e64..845012405 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -462,7 +462,6 @@ mod str; pub mod number; -#[cfg(any(doc, doctest, feature = "docsrs"))] -#[cfg_attr(feature = "docsrs", cfg_attr(feature = "docsrs", doc = include_str!("../doc/nom_recipes.md")))] +#[cfg(all(std, any(doc, doctest, feature = "docsrs")))] #[cfg_attr(any(doc, doctest, feature = "docsrs"), doc = include_str!("../doc/nom_recipes.md"))] pub mod recipes {} From f19d8a4ac51e63d351c3d35efc54ef96107cd6f2 Mon Sep 17 00:00:00 2001 From: Geoffroy Couprie Date: Sat, 21 Oct 2023 18:18:58 +0200 Subject: [PATCH 5/5] properly specify the feature gate --- src/lib.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/lib.rs b/src/lib.rs index 845012405..295710192 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -462,6 +462,6 @@ mod str; pub mod number; -#[cfg(all(std, any(doc, doctest, feature = "docsrs")))] +#[cfg(all(feature = "std", any(doc, doctest, feature = "docsrs")))] #[cfg_attr(any(doc, doctest, feature = "docsrs"), doc = include_str!("../doc/nom_recipes.md"))] pub mod recipes {}