Ran into issue with heading, naming this type is going to be a nightmare.

This commit is contained in:
Tom Alexander 2023-09-27 15:56:45 -04:00
parent 4359fc9266
commit ab46a9e5c6
Signed by: talexander
GPG Key ID: D3A179C9A53C0EDE
2 changed files with 37 additions and 35 deletions

View File

@ -9,6 +9,7 @@ use crate::types::Comment;
use crate::types::CommentBlock; use crate::types::CommentBlock;
use crate::types::DiarySexp; use crate::types::DiarySexp;
use crate::types::Document; use crate::types::Document;
use crate::types::DocumentElement;
use crate::types::Drawer; use crate::types::Drawer;
use crate::types::DynamicBlock; use crate::types::DynamicBlock;
use crate::types::Element; use crate::types::Element;
@ -111,6 +112,15 @@ pub enum AstNode<'r, 's> {
Timestamp(&'r Timestamp<'s>), Timestamp(&'r Timestamp<'s>),
} }
impl<'r, 's> From<&'r DocumentElement<'s>> for AstNode<'r, 's> {
fn from(value: &'r DocumentElement<'s>) -> Self {
match value {
DocumentElement::Heading(inner) => inner.into(),
DocumentElement::Section(inner) => inner.into(),
}
}
}
impl<'r, 's> From<&'r Element<'s>> for AstNode<'r, 's> { impl<'r, 's> From<&'r Element<'s>> for AstNode<'r, 's> {
fn from(value: &'r Element<'s>) -> Self { fn from(value: &'r Element<'s>) -> Self {
match value { match value {

View File

@ -5,8 +5,12 @@ use super::macros::children_iter;
use super::macros::empty_iter; use super::macros::empty_iter;
use crate::types::Bold; use crate::types::Bold;
use crate::types::Code; use crate::types::Code;
use crate::types::Heading;
use crate::types::Italic; use crate::types::Italic;
use crate::types::Object; use crate::types::Object;
use crate::types::PlainText;
use crate::types::RadioLink;
use crate::types::RegularLink;
use crate::types::StrikeThrough; use crate::types::StrikeThrough;
use crate::types::Underline; use crate::types::Underline;
use crate::types::Verbatim; use crate::types::Verbatim;
@ -19,7 +23,7 @@ use crate::types::Verbatim;
pub enum AstNodeIter<'r, 's> { pub enum AstNodeIter<'r, 's> {
// Document Nodes // Document Nodes
// Document(DocumentIter<'r, 's>), // Document(DocumentIter<'r, 's>),
// Heading(HeadingIter<'r, 's>), Heading(HeadingIter<'r, 's>),
// Section(SectionIter<'r, 's>), // Section(SectionIter<'r, 's>),
// Elements // Elements
// Paragraph(ParagraphIter<'r, 's>), // Paragraph(ParagraphIter<'r, 's>),
@ -51,9 +55,9 @@ pub enum AstNodeIter<'r, 's> {
StrikeThrough(StrikeThroughIter<'r, 's>), StrikeThrough(StrikeThroughIter<'r, 's>),
Code(CodeIter<'r, 's>), Code(CodeIter<'r, 's>),
Verbatim(VerbatimIter<'r, 's>), Verbatim(VerbatimIter<'r, 's>),
// PlainText(PlainTextIter<'r, 's>), PlainText(PlainTextIter<'r, 's>),
// RegularLink(RegularLinkIter<'r, 's>), RegularLink(RegularLinkIter<'r, 's>),
// RadioLink(RadioLinkIter<'r, 's>), RadioLink(RadioLinkIter<'r, 's>),
// RadioTarget(RadioTargetIter<'r, 's>), // RadioTarget(RadioTargetIter<'r, 's>),
// PlainLink(PlainLinkIter<'r, 's>), // PlainLink(PlainLinkIter<'r, 's>),
// AngleLink(AngleLinkIter<'r, 's>), // AngleLink(AngleLinkIter<'r, 's>),
@ -74,11 +78,11 @@ pub enum AstNodeIter<'r, 's> {
// Timestamp(TimestampIter<'r, 's>), // Timestamp(TimestampIter<'r, 's>),
} }
pub struct BoldIter<'r, 's> { pub struct HeadingIter<'r, 's> {
next: std::slice::Iter<'r, Object<'s>>, next: std::slice::Iter<'r, Object<'s>>,
} }
impl<'r, 's> Iterator for BoldIter<'r, 's> { impl<'r, 's> Iterator for HeadingIter<'r, 's> {
type Item = AstNode<'r, 's>; type Item = AstNode<'r, 's>;
fn next(&mut self) -> Option<Self::Item> { fn next(&mut self) -> Option<Self::Item> {
@ -86,18 +90,23 @@ impl<'r, 's> Iterator for BoldIter<'r, 's> {
} }
} }
impl<'r, 's> IntoIterator for &'r Bold<'s> { impl<'r, 's> IntoIterator for &'r Heading<'s> {
type Item = AstNode<'r, 's>; type Item = AstNode<'r, 's>;
type IntoIter = BoldIter<'r, 's>; type IntoIter = HeadingIter<'r, 's>;
fn into_iter(self) -> Self::IntoIter { fn into_iter(self) -> Self::IntoIter {
BoldIter { HeadingIter {
next: self.children.iter(), next: self
.title
.iter()
.map(Into::<AstNode>::into)
.chain(self.children.iter().map(Into::<AstNode>::into)),
} }
} }
} }
children_iter!(Bold<'s>, BoldIter, std::slice::Iter<'r, Object<'s>>);
children_iter!(Italic<'s>, ItalicIter, std::slice::Iter<'r, Object<'s>>); children_iter!(Italic<'s>, ItalicIter, std::slice::Iter<'r, Object<'s>>);
children_iter!( children_iter!(
Underline<'s>, Underline<'s>,
@ -109,29 +118,12 @@ children_iter!(
StrikeThroughIter, StrikeThroughIter,
std::slice::Iter<'r, Object<'s>> std::slice::Iter<'r, Object<'s>>
); );
empty_iter!(Code<'s>, CodeIter);
pub struct CodeIter<'r, 's> {
phantom: PhantomData<&'r Code<'s>>,
}
impl<'r, 's> Iterator for CodeIter<'r, 's> {
type Item = AstNode<'r, 's>;
fn next(&mut self) -> Option<Self::Item> {
None
}
}
impl<'r, 's> IntoIterator for &'r Code<'s> {
type Item = AstNode<'r, 's>;
type IntoIter = CodeIter<'r, 's>;
fn into_iter(self) -> Self::IntoIter {
CodeIter {
phantom: PhantomData,
}
}
}
empty_iter!(Verbatim<'s>, VerbatimIter); empty_iter!(Verbatim<'s>, VerbatimIter);
empty_iter!(PlainText<'s>, PlainTextIter);
empty_iter!(RegularLink<'s>, RegularLinkIter);
children_iter!(
RadioLink<'s>,
RadioLinkIter,
std::slice::Iter<'r, Object<'s>>
);