Home / Class/ LoggerHelpDisplay Class — astro Architecture

LoggerHelpDisplay Class — astro Architecture

Architecture documentation for the LoggerHelpDisplay class in logger-help-display.ts from the astro codebase.

Entity Profile

Dependency Diagram

graph TD
  e9da6ffc_2f74_41ea_1bcb_58b6a2429c73["LoggerHelpDisplay"]
  02af4382_f1f9_4658_6be6_d92227300d6a["logger-help-display.ts"]
  e9da6ffc_2f74_41ea_1bcb_58b6a2429c73 -->|defined in| 02af4382_f1f9_4658_6be6_d92227300d6a
  cea8930b_3777_ff80_8983_76cb3d4dee99["constructor()"]
  e9da6ffc_2f74_41ea_1bcb_58b6a2429c73 -->|method| cea8930b_3777_ff80_8983_76cb3d4dee99
  385107ba_0a03_2b28_769a_f0df4075c64c["shouldFire()"]
  e9da6ffc_2f74_41ea_1bcb_58b6a2429c73 -->|method| 385107ba_0a03_2b28_769a_f0df4075c64c
  c66d7c9c_8d90_fc5e_a585_c97f780f3c9d["show()"]
  e9da6ffc_2f74_41ea_1bcb_58b6a2429c73 -->|method| c66d7c9c_8d90_fc5e_a585_c97f780f3c9d

Relationship Graph

Source Code

packages/astro/src/cli/infra/logger-help-display.ts lines 7–89

export class LoggerHelpDisplay implements HelpDisplay {
	readonly #logger: Logger;
	readonly #textStyler: TextStyler;
	readonly #astroVersionProvider: AstroVersionProvider;
	// TODO: find something better
	readonly #flags: Flags;

	constructor({
		logger,
		textStyler,
		astroVersionProvider,
		flags,
	}: {
		logger: Logger;
		textStyler: TextStyler;
		astroVersionProvider: AstroVersionProvider;
		flags: Flags;
	}) {
		this.#logger = logger;
		this.#textStyler = textStyler;
		this.#astroVersionProvider = astroVersionProvider;
		this.#flags = flags;
	}

	shouldFire(): boolean {
		return !!(this.#flags.help || this.#flags.h);
	}

	show({ commandName, description, headline, tables, usage }: HelpPayload): void {
		const linebreak = () => '';
		const title = (label: string) =>
			`  ${this.#textStyler.bgWhite(this.#textStyler.black(` ${label} `))}`;
		const table = (rows: [string, string][], { padding }: { padding: number }) => {
			const split = process.stdout.columns < 60;
			let raw = '';

			for (const row of rows) {
				if (split) {
					raw += `    ${row[0]}\n    `;
				} else {
					raw += `${`${row[0]}`.padStart(padding)}`;
				}
				raw += '  ' + this.#textStyler.dim(row[1]) + '\n';
			}

			return raw.slice(0, -1); // remove latest \n
		};

		let message = [];

		if (headline) {
			message.push(
				linebreak(),
				`${formatVersion({ name: commandName, textStyler: this.#textStyler, astroVersionProvider: this.#astroVersionProvider })} ${headline}`,
			);
		}

		if (usage) {
			message.push(
				linebreak(),
				`  ${this.#textStyler.green(commandName)} ${this.#textStyler.bold(usage)}`,
			);
		}

		if (tables) {
			function calculateTablePadding(rows: [string, string][]) {
				return rows.reduce((val, [first]) => Math.max(val, first.length), 0) + 2;
			}

			const tableEntries = Object.entries(tables);
			const padding = Math.max(...tableEntries.map(([, rows]) => calculateTablePadding(rows)));
			for (const [tableTitle, tableRows] of tableEntries) {
				message.push(linebreak(), title(tableTitle), table(tableRows, { padding }));
			}
		}

		if (description) {
			message.push(linebreak(), `${description}`);
		}

		this.#logger.info('SKIP_FORMAT', message.join('\n') + '\n');

Domain

Frequently Asked Questions

What is the LoggerHelpDisplay class?
LoggerHelpDisplay is a class in the astro codebase, defined in packages/astro/src/cli/infra/logger-help-display.ts.
Where is LoggerHelpDisplay defined?
LoggerHelpDisplay is defined in packages/astro/src/cli/infra/logger-help-display.ts at line 7.

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free