79 lines
2.4 KiB
Plaintext
79 lines
2.4 KiB
Plaintext
import { fileURLToPath } from "url";
|
|
import stripAnsi from "strip-ansi";
|
|
import { isAstroError } from "../errors/errors.js";
|
|
import { isLogLevelEnabled } from "./core.js";
|
|
const PKG_PREFIX = fileURLToPath(new URL("../../../", import.meta.url));
|
|
const E2E_PREFIX = fileURLToPath(new URL("../../../e2e", import.meta.url));
|
|
function isAstroSrcFile(id) {
|
|
return id?.startsWith(PKG_PREFIX) && !id.startsWith(E2E_PREFIX);
|
|
}
|
|
const vitePageReloadMsg = /page reload (.*)( \(.*\))?/;
|
|
const viteHmrUpdateMsg = /hmr update (.*)/;
|
|
const viteBuildMsg = /vite.*building.*for production/;
|
|
function createViteLogger(astroLogger, viteLogLevel = "info") {
|
|
const warnedMessages = /* @__PURE__ */ new Set();
|
|
const loggedErrors = /* @__PURE__ */ new WeakSet();
|
|
const logger = {
|
|
hasWarned: false,
|
|
info(msg) {
|
|
if (!isLogLevelEnabled(viteLogLevel, "info"))
|
|
return;
|
|
const stripped = stripAnsi(msg);
|
|
let m;
|
|
if (m = vitePageReloadMsg.exec(stripped)) {
|
|
if (isAstroSrcFile(m[1]))
|
|
return;
|
|
const extra = m[2] ?? "";
|
|
astroLogger.info("watch", m[1] + extra);
|
|
} else if (m = viteHmrUpdateMsg.exec(stripped)) {
|
|
if (isAstroSrcFile(m[1]))
|
|
return;
|
|
astroLogger.info("watch", m[1]);
|
|
} else if (viteBuildMsg.test(stripped)) {
|
|
} else {
|
|
astroLogger.info("vite", msg);
|
|
}
|
|
},
|
|
warn(msg) {
|
|
if (!isLogLevelEnabled(viteLogLevel, "warn"))
|
|
return;
|
|
logger.hasWarned = true;
|
|
astroLogger.warn("vite", msg);
|
|
},
|
|
warnOnce(msg) {
|
|
if (!isLogLevelEnabled(viteLogLevel, "warn"))
|
|
return;
|
|
if (warnedMessages.has(msg))
|
|
return;
|
|
logger.hasWarned = true;
|
|
astroLogger.warn("vite", msg);
|
|
warnedMessages.add(msg);
|
|
},
|
|
error(msg, opts) {
|
|
if (!isLogLevelEnabled(viteLogLevel, "error"))
|
|
return;
|
|
logger.hasWarned = true;
|
|
const err = opts?.error;
|
|
if (err)
|
|
loggedErrors.add(err);
|
|
if (err && isAstroError(err))
|
|
return;
|
|
if (msg.includes("Error when evaluating SSR module") || msg.includes("Pre-transform error:")) {
|
|
astroLogger.debug("vite", msg);
|
|
return;
|
|
}
|
|
astroLogger.error("vite", msg);
|
|
},
|
|
// Don't allow clear screen
|
|
clearScreen: () => {
|
|
},
|
|
hasErrorLogged(error) {
|
|
return loggedErrors.has(error);
|
|
}
|
|
};
|
|
return logger;
|
|
}
|
|
export {
|
|
createViteLogger
|
|
};
|