summaryrefslogtreecommitdiff
path: root/src/md/visitor/image.rs
diff options
context:
space:
mode:
authorDaniel Silverstone <dsilvers+gitlab@digital-scurf.org>2023-02-01 23:49:11 +0000
committerDaniel Silverstone <dsilvers+gitlab@digital-scurf.org>2023-02-01 23:49:11 +0000
commitb6df0fa5b7046bad97f63dc928a9776cecaee623 (patch)
tree7f2fe57569bdf9d77d0bc30e3fac78ba2d32ff92 /src/md/visitor/image.rs
parente1d63019fdd6f0d24703197b6a6029f26e6f089f (diff)
parentb160ad5b9f0e38859b0a6d3c3262afbb39067584 (diff)
downloadsubplot-b6df0fa5b7046bad97f63dc928a9776cecaee623.tar.gz
Merge branch 'liw/refactor-md' into 'main'
improve Markdown API See merge request subplot/subplot!307
Diffstat (limited to 'src/md/visitor/image.rs')
-rw-r--r--src/md/visitor/image.rs25
1 files changed, 25 insertions, 0 deletions
diff --git a/src/md/visitor/image.rs b/src/md/visitor/image.rs
new file mode 100644
index 0000000..be49d66
--- /dev/null
+++ b/src/md/visitor/image.rs
@@ -0,0 +1,25 @@
+use std::path::PathBuf;
+
+use pandoc_ast::{Inline, MutVisitor};
+
+pub struct ImageVisitor {
+ images: Vec<PathBuf>,
+}
+
+impl ImageVisitor {
+ pub fn new() -> Self {
+ ImageVisitor { images: vec![] }
+ }
+
+ pub fn images(&self) -> Vec<PathBuf> {
+ self.images.clone()
+ }
+}
+
+impl MutVisitor for ImageVisitor {
+ fn visit_inline(&mut self, inline: &mut Inline) {
+ if let Inline::Image(_attr, _inlines, target) = inline {
+ self.images.push(PathBuf::from(&target.0));
+ }
+ }
+}