diff --git a/Readme.md b/Readme.md index f866aa7..8eb2e63 100644 --- a/Readme.md +++ b/Readme.md @@ -161,14 +161,63 @@ Un instalador especializado para DaVinci Resolve, enfocado en sistemas con GPUs - Extrae el instalador, aplica parches a las librerías con `patchelf` y lo copia todo a `/opt/resolve`. - Crea un script "wrapper" y un acceso directo en el menú de aplicaciones para lanzar el programa con la configuración correcta. -### 11. Configuración de Hyprland (`hyprland-config.sh`) +# Verificar que el keyring está corriendo +pgrep -u "$USER" gnome-keyring-daemon +``` + +### ZeroTier no conecta + +```bash +# Verificar servicio +sudo systemctl status zerotier-one + +# Ver logs +sudo journalctl -u zerotier-one -f + +# Reiniciar servicio +sudo systemctl restart zerotier-one + +# Verificar que autorizaste el nodo en https://my.zerotier.com +ztinfo +ztstatus +``` + +### Oh My Posh no se muestra correctamente + +Para que el tema de Oh My Posh se visualice correctamente, es **esencial** tener instalada una "Nerd Font". Estas fuentes incluyen los íconos y símbolos especiales que usa el prompt. + +El script **no** instala fuentes automáticamente, pero puedes hacerlo fácilmente con el siguiente comando: + +```bash +# Instalar la fuente recomendada (Meslo LGM Nerd Font) +oh-my-posh font install meslo +``` + +Después de instalar la fuente, **debes configurar tu emulador de terminal** para que la use. Este paso es crucial y varía según la terminal que utilices (por ejemplo, en GNOME Terminal, Konsole, Alacritty, etc., deberás ir a sus preferencias y seleccionar "MesloLGM Nerd Font"). + +**Verificaciones adicionales:** + +```bash +# Verificar que oh-my-posh está instalado +which oh-my-posh Instala una configuración personalizada para el gestor de ventanas Hyprland. -- **Cómo funciona:** - - Hace una copia de seguridad de tu configuración actual en `~/.config/hypr`. - - Copia el contenido de la carpeta `hypr_config` del repositorio a `~/.config/hypr`. - - Establece el tema de iconos por defecto (Tela Nord) usando el módulo de gestión de iconos. +# Listar fuentes para confirmar que Meslo está instalada +fc-list | grep -i "meslo" +``` + +### El shell no cambió a Zsh + +```bash +# Verificar shell actual +echo $SHELL + +# Cambiar manualmente +chsh -s $(which zsh) + +# Cerrar y abrir nueva terminal +``` --- diff --git a/modules/apps.sh b/modules/apps.sh index ae966f6..9014896 100755 --- a/modules/apps.sh +++ b/modules/apps.sh @@ -19,36 +19,19 @@ SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)" source "${SCRIPT_DIR}/common.sh" -# --------------------------------------------------------------- -# ensure_homebrew_env() -# --------------------------------------------------------------- -# Asegura que el entorno de Homebrew esté configurado correctamente. -# -# Esta función realiza dos tareas principales: -# 1. Carga Homebrew en la sesión de shell actual para que el comando `brew` -# esté disponible inmediatamente después de la instalación. -# 2. Añade la línea de inicialización de Homebrew a los ficheros de -# perfil del usuario (`.profile` y `.zprofile`) para que `brew` -# esté disponible en futuras sesiones de terminal. -# -# Parámetros: -# $1 - Ruta al ejecutable de brew. -# --------------------------------------------------------------- ensure_homebrew_env() { local brew_bin="$1" if [[ ! -x "$brew_bin" ]]; then return 1 fi - # Evalúa `shellenv` para que el resto del módulo pueda usar `brew` - # sin necesidad de reiniciar la shell. + # Eval shellenv so el resto del módulo pueda usar brew sin reiniciar la shell. eval "$("$brew_bin" shellenv)" || return 1 local shell_snippet='eval "$(/home/linuxbrew/.linuxbrew/bin/brew shellenv)"' local -a appended=() local -a rc_targets=("${HOME}/.profile") - # Si el usuario utiliza Zsh, añade también la configuración a .zprofile. if [[ -n "${SHELL:-}" && "$(basename "${SHELL}")" == "zsh" ]]; then rc_targets+=("${HOME}/.zprofile") fi @@ -72,16 +55,6 @@ ensure_homebrew_env() { return 0 } -# --------------------------------------------------------------- -# install_homebrew() -# --------------------------------------------------------------- -# Instala Homebrew (conocido como Linuxbrew en Linux). -# -# Comprueba si Homebrew ya está instalado. Si no lo está, descarga y -# ejecuta el script de instalación oficial de forma no interactiva. -# Después de la instalación, llama a `ensure_homebrew_env` para -# configurar el entorno de shell. -# --------------------------------------------------------------- install_homebrew() { log_step "Instalación de Homebrew (Linuxbrew)" diff --git a/modules/zsh-config.sh b/modules/zsh-config.sh index 148fd81..c048ada 100755 --- a/modules/zsh-config.sh +++ b/modules/zsh-config.sh @@ -24,19 +24,9 @@ else exit 1 fi -# Opciones para `curl` que añaden timeouts y reintentos para robustez. +# Opciones comunes para curl con timeout moderado y reintentos breves. ZSH_CURL_TIMEOUT_OPTS=(--fail --location --silent --show-error --connect-timeout 10 --max-time 60 --retry 2 --retry-delay 2) -# --------------------------------------------------------------- -# zsh_download_with_timeout(url, destination) -# --------------------------------------------------------------- -# Descarga un fichero desde una URL a un destino local usando `curl` -# con las opciones de timeout y reintentos definidas globalmente. -# -# Parámetros: -# $1 - URL del fichero a descargar. -# $2 - Ruta de destino donde se guardará el fichero. -# --------------------------------------------------------------- zsh_download_with_timeout() { local url="$1" local dest="$2" @@ -46,11 +36,6 @@ zsh_download_with_timeout() { return 1 } -# --------------------------------------------------------------- -# install_zsh() -# --------------------------------------------------------------- -# Función principal que orquesta toda la configuración de Zsh. -# --------------------------------------------------------------- install_zsh() { log_step "Configuración Completa de Zsh" @@ -84,16 +69,28 @@ install_zsh() { elif aur_install_packages "oh-my-posh-bin"; then log_success "Oh My Posh instalado desde AUR." else - log_warning "No se pudo instalar Oh My Posh desde pacman ni AUR. Intentando con el script oficial..." - local omp_installer; omp_installer="$(mktemp)" - if zsh_download_with_timeout "https://ohmyposh.dev/install.sh" "$omp_installer"; then - if sudo bash "$omp_installer" -d /usr/local/bin; then - log_success "Oh My Posh instalado con el script oficial." - else - log_error "Falló la instalación de Oh My Posh con el script oficial."; rm -f "$omp_installer"; return 1 - fi; rm -f "$omp_installer" + log_warning "Pacman no pudo instalar oh-my-posh. Intentando con un helper AUR..." + if aur_install_packages "oh-my-posh-bin"; then + log_success "Oh My Posh instalado usando helper AUR (${AUR_HELPER_CMD})." else - log_error "No se pudo descargar el instalador de Oh My Posh."; rm -f "${omp_installer:-}"; return 1 + log_warning "No se pudo instalar Oh My Posh mediante pacman ni AUR." + log_info "Descargando instalador oficial de Oh My Posh..." + local omp_installer + omp_installer="$(mktemp)" + if [[ -n "$omp_installer" ]] && zsh_download_with_timeout "https://ohmyposh.dev/install.sh" "$omp_installer"; then + if sudo bash "$omp_installer" -d /usr/local/bin; then + log_success "Oh My Posh instalado usando el script oficial." + else + log_error "Falló la instalación de Oh My Posh usando el script oficial." + rm -f "$omp_installer" + return 1 + fi + rm -f "$omp_installer" + else + rm -f "${omp_installer:-}" + log_error "No se pudo descargar el instalador oficial de Oh My Posh." + return 1 + fi fi fi else @@ -104,15 +101,25 @@ install_zsh() { local target_ohmyzsh_dir="${target_home}/.oh-my-zsh" if [[ ! -d "$target_ohmyzsh_dir" ]]; then log_info "Instalando Oh My Zsh..." - local omz_installer; omz_installer="$(mktemp)" - if zsh_download_with_timeout "https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh" "$omz_installer"; then - # Se ejecuta de forma no interactiva, sin cambiar el shell aún. - if ! env HOME="$target_home" RUNZSH=no CHSH=no sh "$omz_installer" --unattended --keep-zshrc; then - log_error "Falló la instalación de Oh My Zsh."; rm -f "$omz_installer"; return 1 - fi; rm -f "$omz_installer" - else - log_error "No se pudo descargar el instalador de Oh My Zsh."; rm -f "${omz_installer:-}"; return 1 + local omz_installer + omz_installer="$(mktemp)" + if [[ -z "$omz_installer" ]]; then + log_error "No se pudo crear un archivo temporal para el instalador de Oh My Zsh." + return 1 fi + if zsh_download_with_timeout "https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh" "$omz_installer"; then + # Usar RUNZSH=no para evitar que inicie un nuevo shell y CHSH=no para no cambiar el shell aún + if ! env HOME="$target_home" RUNZSH=no CHSH=no sh "$omz_installer" --unattended --keep-zshrc; then + rm -f "$omz_installer" + log_error "Falló la instalación de Oh My Zsh." + return 1 + fi + else + rm -f "$omz_installer" + log_error "No se pudo descargar el instalador de Oh My Zsh." + return 1 + fi + rm -f "$omz_installer" else log_info "Oh My Zsh ya está instalado." fi @@ -137,8 +144,8 @@ install_zsh() { log_info "Configurando el fichero .zshrc..." local tmp_download="${target_home}/.zshrc.omarchy-tmp" local source_file="" - # Intenta descargar el .zshrc desde el repositorio remoto. - if zsh_download_with_timeout "${REPO_BASE}/.zshrc" "$tmp_download"; then + + if zsh_download_with_timeout "${REPO_BASE}/.zshrc" "$tmp_download" && [[ -s "$tmp_download" ]]; then source_file="$tmp_download" # Si falla, usa la copia local que viene con el script. elif [[ -f "${SCRIPT_DIR_ROOT}/.zshrc" ]]; then @@ -160,11 +167,19 @@ install_zsh() { local posh_themes_dir="${target_home}/.poshthemes" local theme_file="$posh_themes_dir/catppuccin_frappe.omp.json" mkdir -p "$posh_themes_dir" - # Descarga el tema y, si falla, usa la copia local. - if ! zsh_download_with_timeout "https://raw.githubusercontent.com/JanDeDobbeleer/oh-my-posh/main/themes/catppuccin_frappe.omp.json" "$theme_file"; then - if [[ -f "${SCRIPT_DIR_ROOT}/themes/catppuccin_frappe.omp.json" ]]; then - cp "${SCRIPT_DIR_ROOT}/themes/catppuccin_frappe.omp.json" "$theme_file" - log_warning "No se pudo descargar el tema. Se usó la copia local." + + if zsh_download_with_timeout "https://raw.githubusercontent.com/JanDeDobbeleer/oh-my-posh/main/themes/catppuccin_frappe.omp.json" "$theme_file"; then + chmod 644 "$theme_file" 2>/dev/null || true + log_success "Tema Catppuccin Frappe descargado en $theme_file" + else + rm -f "$theme_file" + if [[ -f "$posh_theme_local" ]]; then + if cp "$posh_theme_local" "$theme_file"; then + chmod 644 "$theme_file" 2>/dev/null || true + log_warning "No se pudo descargar el tema remoto. Se utilizó la copia incluida en el repositorio." + else + log_error "No se pudo copiar la versión local del tema Catppuccin." + fi else log_error "No se pudo obtener el tema de Oh My Posh." fi