--- name: refresh_windows_icon_cache kind: function lang: bash domain: infra version: "1.0.0" purity: impure signature: "refresh_windows_icon_cache() -> void" description: "Fuerza a Windows Explorer a recargar la cache de iconos desde WSL2 via ie4uinit.exe. Best-effort: nunca aborta, retorna 0 si alguna estrategia tuvo exito." tags: [windows, wsl, deploy, shell, icons, cpp-windows] uses_functions: [] uses_types: [] returns: [] returns_optional: false error_type: "error_go_core" imports: [] tested: false tests: [] test_file_path: "" file_path: "bash/functions/infra/refresh_windows_icon_cache.sh" params: [] output: "0 si al menos una estrategia tuvo exito, non-zero si todas fallaron. Imprime una linea de estado en stdout." --- ## Ejemplo ```bash source bash/functions/infra/refresh_windows_icon_cache.sh refresh_windows_icon_cache # icon cache refresh: ok via ie4uinit -show ``` O directamente via `fn run`: ```bash ./fn run refresh_windows_icon_cache_bash_infra ``` Uso tipico en un pipeline de redeploy tras reconstruir el `.exe`: ```bash source bash/functions/infra/deploy_cpp_exe_to_windows.sh source bash/functions/infra/refresh_windows_icon_cache.sh deploy_cpp_exe_to_windows "registry_dashboard" "apps/registry_dashboard" refresh_windows_icon_cache ``` ## Cuando usarla Despues de redeployar un `.exe` Windows cuyo `appicon.ico` cambio (via windres embebido en el build), antes de que Windows muestre el icono nuevo en taskbar, Alt+Tab y File Explorer. Sin esta llamada Windows puede tardar minutos en reflejar el icono actualizado, o no actualizarlo hasta reiniciar Explorer. ## Gotchas - `ie4uinit.exe` debe estar en el PATH de WSL2 (normalmente via `/mnt/c/Windows/System32/`). Si Windows esta muy roto puede no encontrarse — la funcion retornara 1 con mensaje de error. - El cambio puede tardar 1-2 segundos en propagarse visualmente despues de que la funcion retorne. - Algunos casos extremos (icono cacheado en el dockable taskbar previamente fijado) requieren desanclar y volver a anclar el ejecutable, o reiniciar `explorer.exe`. Esta funcion no mata Explorer — seria demasiado disruptivo. - Solo funciona desde WSL2 con acceso a herramientas Windows (`/mnt/c/Windows/System32/` en PATH). No tiene efecto en Linux nativo.