format with rustfmt

This commit is contained in:
sspaeti 2024-02-20 18:24:43 +01:00
parent c401da7c05
commit 8cb24ec0b3

View File

@ -19,9 +19,9 @@ use once_cell::sync::Lazy;
use regex::{Captures, Regex};
use serde_json::json;
use gray_matter::Matter;
use gray_matter::engine::YAML;
use serde::Deserialize;
use gray_matter::Matter;
use serde::Deserialize;
fn extract_frontmatter(content: &str) -> Option<&str> {
let start = content.find("---")? + 3; // Find the end of the first `---` + 3 to move past it
@ -29,7 +29,7 @@ fn extract_frontmatter(content: &str) -> Option<&str> {
Some(&content[start..end].trim())
}
#[derive(Deserialize, Debug)]
#[derive(Deserialize, Debug)]
struct FrontMatter {
title: String,
description: String,
@ -75,29 +75,40 @@ impl HtmlHandlebars {
let matter = Matter::<YAML>::new();
let parsed = matter.parse(&ch.content);
let (content, new_content) = if let Some(data) = parsed.data {
debug!("Parsed frontmatter: {:?}", &data);
let yaml_str = extract_frontmatter(&ch.content).unwrap_or_default();
let front_matter_result: Result<FrontMatter, serde_yaml::Error> = serde_yaml::from_str(yaml_str);
let front_matter_result: Result<FrontMatter, serde_yaml::Error> =
serde_yaml::from_str(yaml_str);
// let front_matter_result: Result<FrontMatter, serde_yaml::Error> = serde_yaml::from_str(&ch.content);
match front_matter_result {
Ok(front_matter) => {
ctx.data.insert("is_frontmatter".to_owned(), json!("true"));
ctx.data.insert("og_title".to_owned(), json!(front_matter.title));
ctx.data.insert("og_description".to_owned(), json!(front_matter.description));
ctx.data.insert("og_image_url".to_owned(), json!(front_matter.featured_image_url));
},
ctx.data.insert("is_frontmatter".to_owned(), json!("true"));
ctx.data
.insert("og_title".to_owned(), json!(front_matter.title));
ctx.data
.insert("og_description".to_owned(), json!(front_matter.description));
ctx.data.insert(
"og_image_url".to_owned(),
json!(front_matter.featured_image_url),
);
}
Err(e) => {
eprintln!("Frontmatter: Deserialization error: {:?}", e);
},
}
}
// Prepare new content without frontmatter for rendering
let new_content = parsed.content.trim_start();
(utils::render_markdown(&new_content, ctx.html_config.curly_quotes), Some(new_content))
(
utils::render_markdown(&new_content, ctx.html_config.curly_quotes),
Some(new_content),
)
} else {
// No frontmatter, use original content
(utils::render_markdown(&ch.content, ctx.html_config.curly_quotes), None)
(
utils::render_markdown(&ch.content, ctx.html_config.curly_quotes),
None,
)
};
let fixed_content =
@ -179,8 +190,6 @@ impl HtmlHandlebars {
utils::fs::write_file(&ctx.destination, "index.html", rendered_index.as_bytes())?;
}
Ok(())
}