design-cli-output
О программе
Этот навык помогает разработчикам оформлять терминальный вывод для CLI-инструментов с такими функциями, как цветной текст, индикаторы статуса и множественные форматы вывода (человекочитаемый, подробный, минималистичный, JSON). Он предоставляет рекомендации по архитектуре, кросс-терминальной совместимости и поддержанию единого нарративного стиля. Используйте его при создании нового CLI-репортера, добавлении удобного вывода в существующий инструмент или стандартизации вывода между командами.
Быстрая установка
Claude Code
Рекомендуетсяnpx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/design-cli-outputСкопируйте и вставьте эту команду в Claude Code для установки этого навыка
Документация
Design CLI Output
Diseñar salida de terminal consistente y de múltiples niveles para una herramienta de línea de comandos.
Cuándo Usar
- Construir un nuevo módulo reporter para una herramienta CLI
- Añadir salida cálida o narrativa junto con la salida transaccional estándar
- Estandarizar el formato de salida en múltiples comandos
- Diseñar salida JSON para máquina paralela a la salida legible para humanos
- Elegir colores, glyphs y niveles de verbosidad para una nueva herramienta de terminal
Entradas
- Requerido: Nombre de la herramienta CLI y audiencia primaria (desarrolladores, operadores, usuarios finales)
- Requerido: Comandos que necesitan formato de salida
- Opcional: Si se desea una variante de salida "ceremonial" o narrativa
- Opcional: Restricciones de marca (paleta de colores, tono)
Procedimiento
Paso 1: Definir la Paleta de Colores
Usar chalk para crear un objeto de paleta nombrado:
Paleta estándar (salida transaccional):
let chalk;
try { chalk = (await import('chalk')).default; }
catch { chalk = new Proxy({}, { get: () => (s) => s }); }
// Status colors
const ok = chalk.green; // success
const fail = chalk.red; // errors
const warn = chalk.yellow; // warnings
const info = chalk.cyan; // identifiers, names
const dim = chalk.dim; // secondary info, paths
const bold = chalk.bold; // headers
Paleta cálida (salida ceremonial/narrativa):
const C = {
flame: chalk.hex('#FF6B35'), // active elements, fire
amber: chalk.hex('#FFB347'), // arriving items, warm highlights
spark: chalk.hex('#FFF4E0'), // individual items (sparks/skills)
ember: chalk.hex('#8B4513'), // cold/dormant states
warm: chalk.hex('#D4A574'), // neutral warm text
dim: chalk.dim, // background, secondary
fail: chalk.red, // errors stay red (honest)
};
Reglas de diseño de paleta:
- Siempre proveer un respaldo sin color (el patrón Proxy de arriba)
- Usar colores hex para paletas personalizadas (
chalk.hex('#FF6B35')) - Mantener el color fail/error rojo independientemente del tema de la paleta
- Nombrar entradas de paleta por rol semántico, no por apariencia visual
Esperado: Un objeto de paleta con entradas nombradas y un respaldo sin color.
En caso de fallo: Si chalk no está disponible (salida con pipe, CI), el respaldo Proxy retorna strings sin cambios. Probar con la variable de entorno NO_COLOR=1.
Paso 2: Elegir Indicadores de Estado
Seleccionar glyphs Unicode o caracteres ASCII para comunicación de estado:
ASCII (compatibilidad máxima):
+ created/installed (green)
- removed/deleted (red)
= skipped/unchanged (dim)
! error/warning (red)
Unicode (más rico, necesita terminal UTF-8):
✦ item/skill/practice (spark)
◉ active/burning state
◎ cooling/embers state
○ cold/dormant state
◌ available/not installed
✗ failed item
✓ success (use sparingly — not all terminals render it well)
Criterios de selección:
- ASCII para herramientas que se ejecutan en CI o contextos con pipe
- Unicode para herramientas con usuarios de terminal interactivos
- Ofrecer ambos vía un flag
--asciio detección deNO_COLOR - Probar glyphs en: macOS Terminal, Windows Terminal, terminal de VS Code, sesiones SSH
Esperado: Un conjunto de glyphs que comunica el estado de un vistazo sin depender solo del color.
En caso de fallo: Si un glyph se renderiza como ? o un cuadro en pruebas, reemplazar con el equivalente ASCII. El conjunto +/-/=/! funciona en todas partes.
Paso 3: Diseñar Niveles de Verbosidad
Cada comando debe soportar cuatro niveles de salida:
| Nivel | Flag | Audiencia | Contenido |
|---|---|---|---|
| Default | (ninguno) | Humano en terminal | Formateado, coloreado, informativo |
| Verbose | --verbose o --ceremonial | Humano queriendo detalle | Desglose por item, secuencias de llegada |
| Quiet | --quiet | Scripts, CI | Líneas mínimas, iconos de estado, sin decoración |
| JSON | --json | Consumidores máquina | Estructurado, parseable, completo |
Patrón de implementación:
function output(data, options) {
if (options.json) {
console.log(JSON.stringify(data, null, 2));
return;
}
if (options.quiet) {
for (const item of data.items) {
const icon = item.ok ? '+' : '!';
console.log(`${icon} ${item.id}`);
}
return;
}
// Default (or verbose) human output
printFormatted(data, { verbose: options.verbose });
}
Reglas de salida JSON:
- Siempre JSON válido (sin mezclar con texto humano)
- Incluir todos los datos que muestra la salida humana, más campos útiles para máquina
- Usar nombres de claves consistentes en todos los comandos
- Código de salida 0 para éxito, 1 para errores (independientemente del modo de salida)
Esperado: Cuatro niveles de salida claros con comportamiento consistente entre comandos.
En caso de fallo: Si el modo verbose es demasiado ruidoso, hacerlo opt-in (--ceremonial) en lugar de un nivel de verbosidad gradual.
Paso 4: Establecer Reglas de Voz
Definir el tono y estilo que todas las funciones de salida siguen. Esto previene inconsistencia entre comandos.
Reglas de voz de ejemplo (del reporter campfire):
- Presente, voz activa: "mystic arrives" no "mystic has been installed"
- Sin signos de exclamación: Confianza tranquila. La herramienta no grita.
- La metáfora reemplaza la jerga: "practices" no "dependencies" (solo para modo ceremonia)
- Los fallos son honestos, no catastróficos: "A spark was lost" no "ERROR: installation failed with exit code 1"
- La línea de cierre refleja el estado: Cada operación termina con un resumen de estado
- Sin emoji: Los glyphs Unicode cargan peso visual sin ser decorativos
- Cada palabra carga información: Si una palabra no añade comprensión, eliminarla
Reglas de voz para salida estándar (no ceremonia):
- Líneas concisas y factuales
- Icono de estado + ID del item + contexto
- Línea de resumen con conteos
- Los mensajes de error sugieren acciones correctivas
Esperado: Un conjunto escrito de 3-7 reglas de voz que las funciones de salida deben seguir.
En caso de fallo: Si las reglas se sienten arbitrarias, probarlas: escribir la misma salida con y sin cada regla. Si quitar una regla no cambia la calidad de la salida, la regla no es necesaria.
Paso 5: Implementar Funciones Reporter
Organizar la salida en un módulo reporter con funciones enfocadas:
// reporter.js — standard output
export function printResults(results) { ... }
export function printItemTable(items) { ... }
export function printDetections(detections) { ... }
export function printAudit(auditResults) { ... }
export function printDryRun() { ... }
export function warn(msg) { ... }
export function error(msg) { ... }
export { chalk };
Cada función sigue la misma estructura:
- Manejar entrada vacía/null elegantemente
- Calcular layout (anchos de columna, padding)
- Salida con colores de paleta
- Línea de resumen al fondo
Para salida ceremonial, crear un módulo separado:
// campfire-reporter.js — warm narrative output
export function printArrival({ teamId, agents, results, ceremonial }) { ... }
export function printScatter({ teamId, agents, results }) { ... }
export function printTend(fires) { ... }
export function printCampfireList({ teams, state, reg }) { ... }
export function printFireSummary({ team, fireData, reg }) { ... }
export function printJson(data) { ... }
Esperado: Funciones reporter que son utilizables independientemente — cada una maneja su propio formato sin depender del estado del llamador.
En caso de fallo: Si las funciones crecen más allá de ~50 líneas, extraer helpers. Una función reporter debe ser fácil de revisar de forma aislada.
Paso 6: Probar Salida en Diferentes Entornos
Verificar que la salida se renderiza correctamente en diferentes contextos:
# With colors (interactive terminal)
node cli/index.js list --domains
# Without colors (piped)
node cli/index.js list --domains | cat
# With NO_COLOR environment variable
NO_COLOR=1 node cli/index.js list --domains
# JSON mode (parseable)
node cli/index.js campfire --json | jq .
# In CI (typically no TTY)
CI=true node cli/index.js audit
Verificar:
- Los colores se muestran correctamente en modo interactivo
- Ningún código de escape ANSI se filtra a la salida con pipe/redirigida
- El JSON es válido (pipe a
jq .para verificar) - Los glyphs Unicode se renderizan en los terminales objetivo
- La alineación de columnas se mantiene con anchos de contenido variables
Esperado: La salida es correcta en los cinco contextos.
En caso de fallo: Si los códigos ANSI se filtran, asegurar que chalk respeta NO_COLOR. Si Unicode se rompe, proveer un modo de respaldo ASCII.
Validación
- La paleta de colores tiene un respaldo sin color
- Los indicadores de estado funcionan en modos color y sin color
- Los cuatro niveles de verbosidad producen salida útil
- La salida JSON es válida y parseable por
jq - Las reglas de voz están documentadas y se siguen consistentemente
- Las funciones reporter manejan entrada vacía/null elegantemente
- Salida probada en: terminal, piped, NO_COLOR, CI
Errores Comunes
- Mezclar texto humano con JSON: En modo
--json, emitir solo JSON válido. Una sola línea perdida (como "DRY RUN") rompe los parseadores JSON. Si el comando debe mostrar ambos, separarlos claramente o suprimir el texto humano en modo JSON. - Anchos de columna hardcodeados: La longitud del contenido varía. Usar
Math.max(...items.map(i => i.id.length))para calcular el padding dinámicamente. - Color sin significado: Si el color es la única forma de distinguir éxito de fallo, los usuarios daltónicos y la salida con pipe pierden información. Siempre emparejar el color con un indicador de texto (
+,OK,ERR). - Ceremonia en el contexto incorrecto: La salida narrativa cálida es apropiada para sesiones interactivas de terminal. En CI, scripts o modo
--quiet, añade ruido. Limitar la salida ceremonial detrás de flags explícitos. - Olvidar la línea de resumen: Los usuarios escanean la última línea primero. Cada operación debe terminar con un resumen de una línea (conteos de éxito/fallo/saltado).
Habilidades Relacionadas
scaffold-cli-command— los comandos que usan esta salidatest-cli-application— probar que la salida coincide con las expectativasbuild-cli-plugin— los plugins reportan resultados a través de este sistema de salida
GitHub репозиторий
Похожие навыки
content-collections
МетаЭтот навык предоставляет проверенную в продакшене настройку для Content Collections — TypeScript-ориентированного инструмента, который преобразует файлы Markdown/MDX в типобезопасные коллекции данных с валидацией Zod. Используйте его при создании блогов, сайтов документации или контентных приложений на Vite + React для обеспечения типобезопасности и автоматической проверки содержимого. Он охватывает всё: от настройки плагина Vite и компиляции MDX до оптимизации развертывания и валидации схем.
polymarket
МетаЭтот навык позволяет разработчикам создавать приложения на платформе прогнозных рынков Polymarket, включая интеграцию с API для торговли и получения рыночных данных. Он также обеспечивает потоковую передачу данных в реальном времени через WebSocket для отслеживания текущих сделок и рыночной активности. Используйте его для реализации торговых стратегий или создания инструментов, обрабатывающих обновления рынка в реальном времени.
creating-opencode-plugins
МетаЭтот навык помогает разработчикам создавать плагины OpenCode, которые подключаются к более чем 25 типам событий, таким как команды, файлы и операции LSP. Он предоставляет структуру плагина, спецификации API событий и шаблоны реализации для модулей на JavaScript/TypeScript. Используйте его, когда вам нужно перехватывать, отслеживать или расширять жизненный цикл ассистента OpenCode AI с помощью пользовательской событийно-ориентированной логики.
sglang
МетаSGLang — это высокопроизводительный фреймворк для обслуживания больших языковых моделей (LLM), специализирующийся на быстрой структурированной генерации JSON, regex и рабочих процессов агентов с использованием кэширования префиксов RadixAttention. Он обеспечивает значительно более высокую скорость вывода, особенно для задач с повторяющимися префиксами, что делает его идеальным для сложных структурированных результатов и многократных диалогов. Выбирайте SGLang вместо альтернатив, таких как vLLM, когда вам требуется ограниченное декодирование или вы создаете приложения с интенсивным совместным использованием префиксов.
