use crate::build_common::make_fragment;
use crate::define_function::{FunctionDefSpec, FunctionPropSpec, ord_argument};
use crate::dom_tree::HtmlDomNode;
use crate::mathml_tree::{MathDomNode, MathNode, MathNodeType};
use crate::options::Options;
use crate::parser::parse_node::{AnyParseNode, NodeType, ParseNodeHbox};
use crate::types::{ArgType, Mode, ParseError, ParseErrorKind};
use crate::{KatexContext, build_html, build_mathml};
pub fn define_hbox(ctx: &mut KatexContext) {
ctx.define_function(FunctionDefSpec {
node_type: Some(NodeType::Hbox),
names: &["\\hbox"],
props: FunctionPropSpec {
num_args: 1,
arg_types: Some(vec![ArgType::Mode(Mode::Text)]),
allowed_in_text: true,
primitive: true,
..Default::default()
},
handler: Some(|context, args, _opt_args| {
let body = ord_argument(&args[0]);
Ok(AnyParseNode::Hbox(ParseNodeHbox {
mode: context.parser.mode,
loc: context.loc(),
body,
}))
}),
html_builder: Some(html_builder),
mathml_builder: Some(mathml_builder),
});
}
fn html_builder(
node: &AnyParseNode,
options: &Options,
ctx: &KatexContext,
) -> Result<HtmlDomNode, ParseError> {
let AnyParseNode::Hbox(hbox_node) = node else {
return Err(ParseError::new(ParseErrorKind::ExpectedNode {
node: NodeType::Hbox,
}));
};
let elements = build_html::build_expression(
ctx,
&hbox_node.body,
options,
build_html::GroupType::False,
(None, None),
)?;
Ok(make_fragment(elements).into())
}
fn mathml_builder(
node: &AnyParseNode,
options: &Options,
ctx: &KatexContext,
) -> Result<MathDomNode, ParseError> {
let AnyParseNode::Hbox(hbox_node) = node else {
return Err(ParseError::new(ParseErrorKind::ExpectedNode {
node: NodeType::Hbox,
}));
};
let children = build_mathml::build_expression(ctx, &hbox_node.body, options, None)?;
let mrow = MathNode::builder()
.node_type(MathNodeType::Mrow)
.children(children)
.build();
Ok(MathDomNode::Math(mrow))
}