I think I finally got with_additional_fail_matcher building.
This commit is contained in:
parent
8321c071e4
commit
1506a86d97
@ -1,9 +1,12 @@
|
|||||||
use nom::branch::alt;
|
use nom::branch::alt;
|
||||||
|
use nom::combinator::recognize;
|
||||||
use nom::error::VerboseError;
|
use nom::error::VerboseError;
|
||||||
use nom::IResult;
|
use nom::IResult;
|
||||||
use std::cell::RefCell;
|
use std::cell::RefCell;
|
||||||
use std::rc::Rc;
|
use std::rc::Rc;
|
||||||
|
|
||||||
|
use super::text::bold_end;
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
pub struct NomContext<F>
|
pub struct NomContext<F>
|
||||||
where
|
where
|
||||||
@ -38,17 +41,27 @@ where
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// pub fn with_additional_fail_matcher<G, O>(self, additional_fail_matcher: G) -> NomContext<O>
|
pub fn with_additional_fail_matcher<G>(
|
||||||
// where
|
self,
|
||||||
// G: for<'g> FnMut(&'g str) -> IResult<&'g str, &'g str, VerboseError<&'g str>>,
|
additional_fail_matcher: G,
|
||||||
// G: Clone,
|
) -> NomContext<
|
||||||
// O: for<'o> FnMut(&'o str) -> IResult<&'o str, &'o str, VerboseError<&'o str>>,
|
impl Clone + for<'o> FnMut(&'o str) -> IResult<&'o str, &'o str, VerboseError<&'o str>>,
|
||||||
// O: Clone,
|
>
|
||||||
// {
|
where
|
||||||
|
G: for<'g> FnMut(&'g str) -> IResult<&'g str, &'g str, VerboseError<&'g str>>,
|
||||||
|
G: Clone,
|
||||||
|
{
|
||||||
|
let mut old_fail_matcher_clone = self.fail_matcher.clone();
|
||||||
|
let mut new_context =
|
||||||
|
NomContext::new(move |i| alt((recognize(bold_end), &mut old_fail_matcher_clone))(i));
|
||||||
|
new_context.can_match_bold = self.can_match_bold;
|
||||||
|
new_context.can_match_link = self.can_match_link;
|
||||||
|
|
||||||
// NomContext {
|
// NomContext {
|
||||||
// fail_matcher: move |i| alt((additional_fail_matcher, self.fail_matcher))(i),
|
// fail_matcher: move |i| alt((additional_fail_matcher, &mut old_fail_matcher_clone))(i),
|
||||||
// can_match_bold: self.can_match_bold,
|
// can_match_bold: self.can_match_bold,
|
||||||
// can_match_link: self.can_match_link,
|
// can_match_link: self.can_match_link,
|
||||||
// }
|
// }
|
||||||
// }
|
new_context
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user