pddl 0.1.0

A PDDL 3.1 parser, strongly typed
Documentation
//! Provides parsers for preference names.
use crate::parsers::{parse_name, ParseResult, Span};
use crate::types::PreferenceName;
use nom::combinator::map;

/// Parses a preference name.
///
/// ## Example
/// ```
/// # use pddl::parsers::{parse_pref_name, preamble::*};
/// assert!(parse_pref_name("abcde").is_value("abcde".into()));
///```
pub fn parse_pref_name<'a, T: Into<Span<'a>>>(input: T) -> ParseResult<'a, PreferenceName> {
    map(parse_name, PreferenceName::new)(input.into())
}

impl crate::parsers::Parser for PreferenceName {
    type Item = PreferenceName;

    /// See [`parse_pref_name`].
    fn parse<'a, S: Into<Span<'a>>>(input: S) -> ParseResult<'a, Self::Item> {
        parse_pref_name(input)
    }
}

#[cfg(test)]
mod tests {
    use crate::parsers::preamble::*;
    use crate::PreferenceName;

    #[test]
    fn test_parse() {
        assert!(PreferenceName::parse("abcde").is_value("abcde".into()));
    }
}