Skip to content

Commit

Permalink
chore: smoother logging when building pages (#9487)
Browse files Browse the repository at this point in the history
* chore: smoother logging when building pages

* chore: improve logging during the build

* fix: put `newLine` top `LogMessage`

* Update .changeset/popular-meals-yell.md

Co-authored-by: Florian Lefebvre <contact@florian-lefebvre.dev>

---------

Co-authored-by: Florian Lefebvre <contact@florian-lefebvre.dev>
  • Loading branch information
ematipico and florian-lefebvre authored Dec 20, 2023
1 parent c384f69 commit 19169db
Show file tree
Hide file tree
Showing 4 changed files with 34 additions and 19 deletions.
5 changes: 5 additions & 0 deletions .changeset/popular-meals-yell.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'astro': patch
---

Improves logging of the generated pages during the build
7 changes: 4 additions & 3 deletions packages/astro/src/core/build/generate.ts
Original file line number Diff line number Diff line change
Expand Up @@ -304,13 +304,14 @@ async function generatePage(
for (let i = 0; i < paths.length; i++) {
const path = paths[i];
pipeline.getEnvironment().logger.debug('build', `Generating: ${path}`);
const filePath = getOutputFilename(pipeline.getConfig(), path, pageData.route.type);
const lineIcon = i === paths.length - 1 ? '└─' : '├─';
logger.info(null, ` ${blue(lineIcon)} ${dim(filePath)}`, false);
await generatePath(path, pipeline, generationOptions, route);
const timeEnd = performance.now();
const timeChange = getTimeStat(prevTimeEnd, timeEnd);
const timeIncrease = `(+${timeChange})`;
const filePath = getOutputFilename(pipeline.getConfig(), path, pageData.route.type);
const lineIcon = i === paths.length - 1 ? '└─' : '├─';
logger.info(null, ` ${blue(lineIcon)} ${dim(filePath)} ${dim(timeIncrease)}`);
logger.info('SKIP_FORMAT', ` ${dim(timeIncrease)}`);
prevTimeEnd = timeEnd;
}
}
Expand Down
34 changes: 21 additions & 13 deletions packages/astro/src/core/logger/core.ts
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ export interface LogMessage {
label: string | null;
level: LoggerLevel;
message: string;
newLine: boolean;
}

export const levels: Record<LoggerLevel, number> = {
Expand All @@ -67,13 +68,20 @@ export const levels: Record<LoggerLevel, number> = {
};

/** Full logging API */
export function log(opts: LogOptions, level: LoggerLevel, label: string | null, message: string) {
export function log(
opts: LogOptions,
level: LoggerLevel,
label: string | null,
message: string,
newLine = true
) {
const logLevel = opts.level;
const dest = opts.dest;
const event: LogMessage = {
label,
level,
message,
newLine,
};

// test if this level is enabled or not
Expand All @@ -89,18 +97,18 @@ export function isLogLevelEnabled(configuredLogLevel: LoggerLevel, level: Logger
}

/** Emit a user-facing message. Useful for UI and other console messages. */
export function info(opts: LogOptions, label: string | null, message: string) {
return log(opts, 'info', label, message);
export function info(opts: LogOptions, label: string | null, message: string, newLine = true) {
return log(opts, 'info', label, message, newLine);
}

/** Emit a warning message. Useful for high-priority messages that aren't necessarily errors. */
export function warn(opts: LogOptions, label: string | null, message: string) {
return log(opts, 'warn', label, message);
export function warn(opts: LogOptions, label: string | null, message: string, newLine = true) {
return log(opts, 'warn', label, message, newLine);
}

/** Emit a error message, Useful when Astro can't recover from some error. */
export function error(opts: LogOptions, label: string | null, message: string) {
return log(opts, 'error', label, message);
export function error(opts: LogOptions, label: string | null, message: string, newLine = true) {
return log(opts, 'error', label, message, newLine);
}

type LogFn = typeof info | typeof warn | typeof error;
Expand Down Expand Up @@ -191,14 +199,14 @@ export class Logger {
this.options = options;
}

info(label: LoggerLabel | null, message: string) {
info(this.options, label, message);
info(label: LoggerLabel | null, message: string, newLine = true) {
info(this.options, label, message, newLine);
}
warn(label: LoggerLabel | null, message: string) {
warn(this.options, label, message);
warn(label: LoggerLabel | null, message: string, newLine = true) {
warn(this.options, label, message, newLine);
}
error(label: LoggerLabel | null, message: string) {
error(this.options, label, message);
error(label: LoggerLabel | null, message: string, newLine = true) {
error(this.options, label, message, newLine);
}
debug(label: LoggerLabel, ...messages: any[]) {
debug(label, ...messages);
Expand Down
7 changes: 4 additions & 3 deletions packages/astro/src/core/logger/node.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,15 +7,16 @@ type ConsoleStream = Writable & {
};

export const nodeLogDestination: LogWritable<LogMessage> = {
write(event: LogMessage) {
write(event: LogMessage, newLine = true) {
let dest: ConsoleStream = process.stderr;
if (levels[event.level] < levels['error']) {
dest = process.stdout;
}
let trailingLine = event.newLine ? '\n' : '';
if (event.label === 'SKIP_FORMAT') {
dest.write(event.message + '\n');
dest.write(event.message + trailingLine);
} else {
dest.write(getEventPrefix(event) + ' ' + event.message + '\n');
dest.write(getEventPrefix(event) + ' ' + event.message + trailingLine);
}
return true;
},
Expand Down

0 comments on commit 19169db

Please sign in to comment.