From 771110a72ae005da42169da261f8b8513c9421db Mon Sep 17 00:00:00 2001
From: Jacky Zhao <j.zhao2k19@gmail.com>
Date: Tue, 18 Mar 2025 15:56:06 +0000
Subject: [PATCH] fix(git): deprioritize git, dont fail on non-git content folders
---
quartz/plugins/transformers/lastmod.ts | 42 ++++++++++++++++++++----------------------
1 files changed, 20 insertions(+), 22 deletions(-)
diff --git a/quartz/plugins/transformers/lastmod.ts b/quartz/plugins/transformers/lastmod.ts
index 31c8c20..e17d894 100644
--- a/quartz/plugins/transformers/lastmod.ts
+++ b/quartz/plugins/transformers/lastmod.ts
@@ -27,49 +27,47 @@
}
type MaybeDate = undefined | string | number
-export const CreatedModifiedDate: QuartzTransformerPlugin<Partial<Options> | undefined> = (
- userOpts,
-) => {
+export const CreatedModifiedDate: QuartzTransformerPlugin<Partial<Options>> = (userOpts) => {
const opts = { ...defaultOptions, ...userOpts }
return {
name: "CreatedModifiedDate",
- markdownPlugins() {
+ markdownPlugins(ctx) {
return [
() => {
let repo: Repository | undefined = undefined
+ if (opts.priority.includes("git")) {
+ try {
+ repo = Repository.discover(ctx.argv.directory)
+ } catch (e) {
+ console.log(
+ chalk.yellow(`\nWarning: couldn't find git repository for ${ctx.argv.directory}`),
+ )
+ }
+ }
+
return async (_tree, file) => {
let created: MaybeDate = undefined
let modified: MaybeDate = undefined
let published: MaybeDate = undefined
- const fp = file.data.filePath!
- const fullFp = path.posix.join(file.cwd, fp)
+ const fp = file.data.relativePath!
+ const fullFp = file.data.filePath!
for (const source of opts.priority) {
if (source === "filesystem") {
const st = await fs.promises.stat(fullFp)
created ||= st.birthtimeMs
modified ||= st.mtimeMs
} else if (source === "frontmatter" && file.data.frontmatter) {
- created ||= file.data.frontmatter.date as MaybeDate
- modified ||= file.data.frontmatter.lastmod as MaybeDate
- modified ||= file.data.frontmatter.updated as MaybeDate
- modified ||= file.data.frontmatter["last-modified"] as MaybeDate
- published ||= file.data.frontmatter.publishDate as MaybeDate
- } else if (source === "git") {
- if (!repo) {
- // Get a reference to the main git repo.
- // It's either the same as the workdir,
- // or 1+ level higher in case of a submodule/subtree setup
- repo = Repository.discover(file.cwd)
- }
-
+ created ||= file.data.frontmatter.created as MaybeDate
+ modified ||= file.data.frontmatter.modified as MaybeDate
+ published ||= file.data.frontmatter.published as MaybeDate
+ } else if (source === "git" && repo) {
try {
- modified ||= await repo.getFileLatestModifiedDateAsync(file.data.filePath!)
+ modified ||= await repo.getFileLatestModifiedDateAsync(fullFp)
} catch {
console.log(
chalk.yellow(
- `\nWarning: ${file.data
- .filePath!} isn't yet tracked by git, last modification date is not available for this file`,
+ `\nWarning: ${file.data.filePath!} isn't yet tracked by git, dates will be inaccurate`,
),
)
}
--
Gitblit v1.10.0