Files
fn_registry/functions/infra/scan_issues_dir.md
T
egutierrez 7913116a8e chore: auto-commit (129 archivos)
- .claude/agents/fn-analizador/SKILL.md
- .claude/agents/fn-constructor/SKILL.md
- .claude/agents/fn-executor/SKILL.md
- .claude/agents/fn-mejorador/SKILL.md
- .claude/agents/fn-orquestador/SKILL.md
- .claude/agents/fn-recopilador/SKILL.md
- .claude/commands/app.md
- .claude/commands/compile.md
- .claude/commands/cpp-app.md
- .claude/commands/create_functions.md
- ...

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-06-01 22:23:12 +02:00

2.2 KiB

name, kind, lang, domain, version, purity, signature, description, tags, uses_functions, uses_types, returns, returns_optional, error_type, imports, params, output, tested, tests, test_file_path, file_path
name kind lang domain version purity signature description tags uses_functions uses_types returns returns_optional error_type imports params output tested tests test_file_path file_path
scan_issues_dir function go infra 0.1.0 impure func ScanIssuesDir(root string) ([]Issue, error) Escanea el directorio dev/issues/ (root) y devuelve todos los Issues encontrados en *.md directos y en completed/*.md. Si un archivo falla al parsearse emite un warning al log y continua. Resultado ordenado por ID ascendente.
issue
scanner
frontmatter
yaml
dev-ux
kanban
parse_issue_md_go_infra
issue_go_infra
issue_go_infra
false error_go_core
fmt
log
os
path/filepath
sort
strings
name desc
root Ruta al directorio dev/issues/ (absoluta o relativa). Debe existir o retorna error.
Slice de Issue ordenado por ID asc. Incluye issues de completed/ con Completed=true. Issues con YAML malformado se omiten con warning. true
scan devuelve al menos 90 issues
issue 0130 esta presente
issues ordenados por ID asc
completed issues tienen Completed=true
directorio inexistente retorna error
functions/infra/scan_issues_dir_test.go functions/infra/scan_issues_dir.go

Ejemplo

issues, err := infra.ScanIssuesDir("$HOME/fn_registry/dev/issues")
if err != nil {
    log.Fatal(err)
}
fmt.Printf("Total issues: %d\n", len(issues))
for _, iss := range issues {
    fmt.Printf("  %s [%s] %s\n", iss.ID, iss.Status, iss.Title)
}

Cuando usarla

Al arrancar el backend de kanban_cpp para poblar la cache SQLite inicial. Tambien util para cualquier herramienta que necesite un snapshot completo de todos los issues del proyecto (stats, dashboards, fn doctor).

Gotchas

  • Skippea automaticamente INDEX.md y README.md — no son issues.
  • Si completed/ no existe (no hay issues completados), no retorna error — devuelve los issues directos.
  • La ordenacion es lexicografica por ID string, no numerica. "0099" < "0100" funciona bien con el formato de 4 digitos del registry.
  • Un issue con YAML invalido no aborta el scan entero — solo ese archivo se omite con un log.Printf warning. Si necesitas comportamiento strict (abort en primer error), parsea manualmente con ParseIssueMd.