From c538c151c7462ad0395ff2c15c5e11e89e362aa8 Mon Sep 17 00:00:00 2001
From: Striven <sg.striven@cutecat.club>
Date: Sat, 04 Apr 2026 19:47:16 +0000
Subject: [PATCH] Initial commit
---
quartz/worker.ts | 57 ++++++++++++++++++++++++++++++++-------------------------
1 files changed, 32 insertions(+), 25 deletions(-)
diff --git a/quartz/worker.ts b/quartz/worker.ts
index 71678b8..f4cf4c6 100644
--- a/quartz/worker.ts
+++ b/quartz/worker.ts
@@ -1,30 +1,37 @@
-import { read } from "to-vfile"
-import config from "../quartz.config"
-import { createProcessor } from "./processors/parse"
-import { slugify } from "./path"
-import path from "path"
-import { ProcessedContent } from "./plugins/vfile"
-
-const transformers = config.plugins.transformers
-const processor = createProcessor(transformers)
+import sourceMapSupport from "source-map-support"
+sourceMapSupport.install(options)
+import cfg from "../quartz.config"
+import { BuildCtx, WorkerSerializableBuildCtx } from "./util/ctx"
+import { FilePath } from "./util/path"
+import {
+ createFileParser,
+ createHtmlProcessor,
+ createMarkdownParser,
+ createMdProcessor,
+} from "./processors/parse"
+import { options } from "./util/sourcemap"
+import { MarkdownContent, ProcessedContent } from "./plugins/vfile"
// only called from worker thread
-export async function parseFiles(baseDir: string, fps: string[], verbose: boolean) {
- const res: ProcessedContent[] = []
- for (const fp of fps) {
- const file = await read(fp)
-
- // base data properties that plugins may use
- file.data.slug = slugify(path.relative(baseDir, file.path))
- file.data.filePath = fp
-
- const ast = processor.parse(file)
- res.push([await processor.run(ast, file), file])
-
- if (verbose) {
- console.log(`[process] ${fp} -> ${file.data.slug}`)
- }
+export async function parseMarkdown(
+ partialCtx: WorkerSerializableBuildCtx,
+ fps: FilePath[],
+): Promise<MarkdownContent[]> {
+ const ctx: BuildCtx = {
+ ...partialCtx,
+ cfg,
}
+ return await createFileParser(ctx, fps)(createMdProcessor(ctx))
+}
- return res
+// only called from worker thread
+export function processHtml(
+ partialCtx: WorkerSerializableBuildCtx,
+ mds: MarkdownContent[],
+): Promise<ProcessedContent[]> {
+ const ctx: BuildCtx = {
+ ...partialCtx,
+ cfg,
+ }
+ return createMarkdownParser(ctx, mds)(createHtmlProcessor(ctx))
}
--
Gitblit v1.10.0