fc4180cbb3
- .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>
2.0 KiB
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
discover_git_repos_bash_infra— lista repos locales (mismas exclusiones que push).git_pull_with_stash_bash_infrapor repo: stash si dirty → fetch → pull --ff-only → pop. Estados posibles por repo:[pulled],[up-to-date],[diverged],[stash-conflict].git submodule update --init --recursiveen root.git_pull_with_stashsobre~/.password-store.CGO_ENABLED=1 ./fn indexpara regenerarregistry.db../fn synccon credenciales depass.
Notas
- Modo no-interactivo. Auto-stash con
--include-untracked. - Fast-forward + merge auto. Si
pull --ff-onlyfalla por divergencia, el pipeline intentagit 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_locationspara 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:
- Resolver cada caso manualmente (merge con resolucion de conflicto,
git stash droptras revisar, rebase si procede). - Volver a ejecutar
/full-git-pullhasta salida limpia. - Tras
/full-git-pull, si hubo[merged-auto], ejecutar/full-git-pushpara 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.