Create structure for targets.

This commit is contained in:
Tom Alexander
2023-07-22 01:15:04 -04:00
parent 537fc00fd3
commit d60cad07e0
4 changed files with 41 additions and 0 deletions

View File

@@ -50,6 +50,7 @@ use crate::parser::StrikeThrough;
use crate::parser::Table;
use crate::parser::TableCell;
use crate::parser::TableRow;
use crate::parser::Target;
use crate::parser::Underline;
use crate::parser::Verbatim;
use crate::parser::VerseBlock;
@@ -172,6 +173,7 @@ fn compare_object<'s>(
Object::InlineBabelCall(obj) => compare_inline_babel_call(source, emacs, obj),
Object::InlineSourceBlock(obj) => compare_inline_source_block(source, emacs, obj),
Object::LineBreak(obj) => compare_line_break(source, emacs, obj),
Object::Target(obj) => compare_target(source, emacs, obj),
}
}
@@ -1463,3 +1465,26 @@ fn compare_line_break<'s>(
children: Vec::new(),
})
}
fn compare_target<'s>(
source: &'s str,
emacs: &'s Token<'s>,
rust: &'s Target<'s>,
) -> Result<DiffResult, Box<dyn std::error::Error>> {
let mut this_status = DiffStatus::Good;
let emacs_name = "target";
if assert_name(emacs, emacs_name).is_err() {
this_status = DiffStatus::Bad;
}
if assert_bounds(source, emacs, rust).is_err() {
this_status = DiffStatus::Bad;
}
Ok(DiffResult {
status: this_status,
name: emacs_name.to_owned(),
message: None,
children: Vec::new(),
})
}