Home / Function/ printHelp() — astro Function Reference

printHelp() — astro Function Reference

Architecture documentation for the printHelp() function in messages.ts from the astro codebase.

Entity Profile

Dependency Diagram

graph TD
  4bf38b79_4247_2fd9_97cb_2cc20f8aadf4["printHelp()"]
  a89de736_d85a_fc8a_68a9_5d9ea54128d5["messages.ts"]
  4bf38b79_4247_2fd9_97cb_2cc20f8aadf4 -->|defined in| a89de736_d85a_fc8a_68a9_5d9ea54128d5
  style 4bf38b79_4247_2fd9_97cb_2cc20f8aadf4 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

packages/astro/src/core/messages.ts lines 313–377

export function printHelp({
	commandName,
	headline,
	usage,
	tables,
	description,
}: {
	commandName: string;
	headline?: string;
	usage?: string;
	tables?: Record<string, [command: string, help: string][]>;
	description?: string;
}) {
	const linebreak = () => '';
	const title = (label: string) => `  ${bgWhite(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 += '  ' + dim(row[1]) + '\n';
		}

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

	let message = [];

	if (headline) {
		message.push(
			linebreak(),
			`  ${bgGreen(black(` ${commandName} `))} ${green(
				`v${process.env.PACKAGE_VERSION ?? ''}`,
			)} ${headline}`,
		);
	}

	if (usage) {
		message.push(linebreak(), `  ${green(commandName)} ${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}`);
	}

	// biome-ignore lint/suspicious/noConsole: allowed
	console.log(message.join('\n') + '\n');
}

Domain

Subdomains

Frequently Asked Questions

What does printHelp() do?
printHelp() is a function in the astro codebase, defined in packages/astro/src/core/messages.ts.
Where is printHelp() defined?
printHelp() is defined in packages/astro/src/core/messages.ts at line 313.

Analyze Your Own Codebase

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

Try Supermodel Free