Files
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.0 KiB

/full-git-pull — Pull automático de fn_registry + sub-repos + submodules + fn sync

Wrapper sobre el pipeline full_git_pull_bash_pipelines. Toda la lógica vive en el registry. Este comando solo ejecuta:

cd $HOME/fn_registry
./fn run full_git_pull_bash_pipelines

Argumento

$ARGUMENTS — sin uso, ignorar.

Qué hace el pipeline

  1. discover_git_repos_bash_infra — lista repos locales (mismas exclusiones que push).
  2. git_pull_with_stash_bash_infra por repo: stash si dirty → fetch → pull --ff-only → pop. Estados posibles por repo: [pulled], [up-to-date], [diverged], [stash-conflict].
  3. git submodule update --init --recursive en root.
  4. git_pull_with_stash sobre ~/.password-store.
  5. CGO_ENABLED=1 ./fn index para regenerar registry.db.
  6. ./fn sync con credenciales de pass.

Notas

  • Modo no-interactivo. Auto-stash con --include-untracked.
  • Fast-forward + merge auto. Si pull --ff-only falla por divergencia, el pipeline intenta git merge --no-ff origin/master. Si el merge se aplica sin conflictos lo conserva como [merged-auto]. Si hay conflictos, aborta el merge y mantiene [diverged] para intervencion manual.
  • No clona repos faltantes. Cada PC tiene su subset. Para añadir uno, clonarlo a mano y mirar pc_locations para reproducir el path.
  • Para tocar la lógica: editar las funciones del registry, no este wrapper.

Obligaciones del agente

El pipeline retorna exit code distinto de 0 si tras los intentos automaticos siguen quedando repos [diverged] o [stash-conflict]. En ese caso el agente DEBE:

  1. Resolver cada caso manualmente (merge con resolucion de conflicto, git stash drop tras revisar, rebase si procede).
  2. Volver a ejecutar /full-git-pull hasta salida limpia.
  3. Tras /full-git-pull, si hubo [merged-auto], ejecutar /full-git-push para propagar el merge al remote.

Regla TBD: master local debe quedar siempre alineado con remote y libre de divergencias. Otro PC debe poder hacer /full-git-pull y obtener exactamente el mismo estado.