ratex-parser 0.1.1

LaTeX parser for RaTeX
Documentation
use std::collections::HashMap;

use crate::error::{ParseError, ParseResult};
use crate::functions::{define_function_full, ArgType, FunctionContext, FunctionSpec};
use crate::parse_node::ParseNode;

pub fn register(map: &mut HashMap<&'static str, FunctionSpec>) {
    define_function_full(
        map,
        &["\\rule"],
        "rule",
        2, 1,
        Some(vec![ArgType::Size, ArgType::Size, ArgType::Size]),
        false,
        true, true,
        false, false,
        handle_rule,
    );
}

fn handle_rule(
    ctx: &mut FunctionContext,
    args: Vec<ParseNode>,
    opt_args: Vec<Option<ParseNode>>,
) -> ParseResult<ParseNode> {
    let shift = opt_args.into_iter().next().flatten().and_then(|n| {
        if let ParseNode::Size { value, .. } = n {
            Some(value)
        } else {
            None
        }
    });

    let mut args = args.into_iter();
    let width = match args.next() {
        Some(ParseNode::Size { value, .. }) => value,
        _ => return Err(ParseError::msg("Expected size for \\rule width")),
    };
    let height = match args.next() {
        Some(ParseNode::Size { value, .. }) => value,
        _ => return Err(ParseError::msg("Expected size for \\rule height")),
    };

    Ok(ParseNode::Rule {
        mode: ctx.parser.mode,
        shift,
        width,
        height,
        loc: None,
    })
}