pddl 0.1.0

A PDDL 3.1 parser, strongly typed
Documentation
//! Provides parsers for optimization.

use crate::parsers::{ParseResult, Span};
use crate::types::{optimization::names, Optimization};
use nom::branch::alt;
use nom::bytes::complete::tag;
use nom::combinator::map;

/// Parses an optimization goal, i.e. `minimize | maximize`.
///
/// ## Example
/// ```
/// # use pddl::parsers::{parse_optimization, preamble::*};
/// # use pddl::{Optimization};
/// assert!(parse_optimization("minimize").is_value(Optimization::Minimize));
/// assert!(parse_optimization("maximize").is_value(Optimization::Maximize));
///```
pub fn parse_optimization<'a, T: Into<Span<'a>>>(input: T) -> ParseResult<'a, Optimization> {
    map(
        alt((tag(names::MINIMIZE), tag(names::MAXIMIZE))),
        |x: Span| Optimization::try_from(*x.fragment()).expect("unhandled variant"),
    )(input.into())
}

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

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

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

    #[test]
    fn test_parse() {
        assert!(Optimization::parse("minimize").is_value(Optimization::Minimize));
        assert!(Optimization::parse("maximize").is_value(Optimization::Maximize));
    }
}