#!/usr/bin/env bash # sync-ai-instructions.sh # Génère un unique CLAUDE.md dans le repo Lead_tech depuis _AI_INSTRUCTIONS.md + _projects.conf # puis recrée les liens symboliques nécessaires vers ce fichier unique # selon la machine courante (Darwin = Mac, Linux = NUC) set -euo pipefail SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)" REPO_ROOT="$(cd "$SCRIPT_DIR/.." && pwd)" SOURCE="$REPO_ROOT/_AI_INSTRUCTIONS.md" # --- Détection machine --- OS="$(uname -s)" CHANGED=0 generate_repo_claude() { local header="$1" local dest="$2" local tmp tmp="$(mktemp)" mkdir -p "$(dirname "$dest")" { echo "$header" echo "" cat "$SOURCE" } > "$tmp" if [ ! -f "$dest" ] || ! cmp -s "$tmp" "$dest"; then mv "$tmp" "$dest" CHANGED=1 else rm -f "$tmp" fi } ensure_symlink() { local target="$1" local link_path="$2" mkdir -p "$(dirname "$link_path")" if [ -L "$link_path" ]; then local current_target current_target="$(readlink "$link_path")" if [ "$current_target" = "$target" ]; then return 0 fi elif [ -e "$link_path" ]; then rm -f "$link_path" fi ln -s "$target" "$link_path" CHANGED=1 } CLAUDE_HEADER="# Instructions globales — Lead Tech Copilote Ce fichier est chargé automatiquement par Claude Code ou Codex à chaque session. Il constitue la porte d'entrée principale de la base de connaissance Lead_tech et oriente vers les fichiers spécialisés utilisés par tous les projets." generate_repo_claude "$CLAUDE_HEADER" "$REPO_ROOT/CLAUDE.md" ensure_symlink "$REPO_ROOT/CLAUDE.md" "$HOME/.claude/CLAUDE.md" ensure_symlink "$HOME/.claude/CLAUDE.md" "$HOME/.codex/AGENTS.md" ensure_symlink "$REPO_ROOT/CLAUDE.md" "$REPO_ROOT/AGENTS.md" if [ "$CHANGED" -eq 1 ]; then echo "Sync AI instructions (OS: $OS)" echo "Sync terminée." fi