| | |
| | | import { randomUUID } from "crypto" |
| | | import { Mutex } from "async-mutex" |
| | | import { CreateArgv } from "./args.js" |
| | | import { globby } from "globby" |
| | | import { |
| | | exitIfCancel, |
| | | escapePath, |
| | |
| | | } |
| | | |
| | | if (cleanupBuild) { |
| | | await cleanupBuild() |
| | | console.log(chalk.yellow("Detected a source code change, doing a hard rebuild...")) |
| | | await cleanupBuild() |
| | | } |
| | | |
| | | const result = await ctx.rebuild().catch((err) => { |
| | |
| | | source: "**/*.*", |
| | | headers: [{ key: "Content-Disposition", value: "inline" }], |
| | | }, |
| | | { |
| | | source: "**/*.webp", |
| | | headers: [{ key: "Content-Type", value: "image/webp" }], |
| | | }, |
| | | // fixes bug where avif images are displayed as text instead of images (future proof) |
| | | { |
| | | source: "**/*.avif", |
| | | headers: [{ key: "Content-Type", value: "image/avif" }], |
| | | }, |
| | | ], |
| | | }) |
| | | const status = res.statusCode |
| | |
| | | ), |
| | | ) |
| | | console.log("hint: exit with ctrl+c") |
| | | const paths = await globby(["**/*.ts", "**/*.tsx", "**/*.scss", "package.json"]) |
| | | chokidar |
| | | .watch(["**/*.ts", "**/*.tsx", "**/*.scss", "package.json"], { |
| | | ignoreInitial: true, |
| | | }) |
| | | .on("all", async () => { |
| | | build(clientRefresh) |
| | | }) |
| | | .watch(paths, { ignoreInitial: true }) |
| | | .on("add", () => build(clientRefresh)) |
| | | .on("change", () => build(clientRefresh)) |
| | | .on("unlink", () => build(clientRefresh)) |
| | | } else { |
| | | await build(() => {}) |
| | | ctx.dispose() |