11 Commits

Author SHA1 Message Date
Jose Luis Montañes Ojados
ed8f9a4538 ci: set linux job to run on x86_64 host runner
All checks were successful
Build and Release / build-linux (push) Successful in 34s
Build and Release / build-windows (push) Successful in 1m54s
Build and Release / release (push) Successful in 29s
2026-01-17 02:54:39 +01:00
Jose Luis Montañes Ojados
1283fdc9c4 ci: consolidate build workflows and automate Gitea releases 2026-01-17 02:54:04 +01:00
Jose Luis Montañes Ojados
71017f1e61 ci: add architecture suffixes and document WSL2 runner setup 2026-01-17 02:47:15 +01:00
Jose Luis Montañes Ojados
81d73e9b08 ci: disable go cache to prevent hangs on self-hosted runner
All checks were successful
Build Linux / build-linux (push) Successful in 57s
Build Windows / build-windows (push) Successful in 2m19s
2026-01-17 02:40:11 +01:00
Jose Luis Montañes Ojados
36111ff781 fix: linux arm64 build error (Dup2 is not available, use unix.Dup2) 2026-01-17 02:38:50 +01:00
Jose Luis Montañes Ojados
3a1db4e80c ci: bundle required DLLs in Windows artifact 2026-01-17 02:38:03 +01:00
Jose Luis Montañes Ojados
7284b9d4b9 ci: downgrade upload-artifact to v3 for Gitea compatibility
Some checks failed
Build Linux / build-linux (push) Failing after 5m46s
Build Windows / build-windows (push) Has been cancelled
2026-01-17 02:31:21 +01:00
Jose Luis Montañes Ojados
206f158c8e ci: fix dependencies and Go path for Gitea Actions
Some checks failed
Build Windows / build-windows (push) Failing after 2m16s
Build Linux / build-linux (push) Has been cancelled
2026-01-17 02:28:13 +01:00
Jose Luis Montañes Ojados
2cd818c331 ci: fix Gitea CI workflows to build the TUI application for Linux and Windows.
Some checks failed
Build Windows / build-windows (push) Failing after 1m56s
Build Linux / build-linux (push) Has been cancelled
2026-01-17 02:24:02 +01:00
Jose Luis Montañes Ojados
952552302a ci: add Linux and Windows build workflow for Gitea Actions
Some checks failed
Build Windows / build-windows (push) Failing after 5m13s
Build Linux / build-linux (push) Failing after 6m41s
Gitea Actions Demo / Explore-Gitea-Actions (push) Successful in 5s
2026-01-17 02:15:39 +01:00
Jose Luis Montañes Ojados
b6224cd2fd feat: Add Gitea Actions demo workflow.
All checks were successful
Gitea Actions Demo / Explore-Gitea-Actions (push) Successful in 5s
2026-01-17 02:05:54 +01:00
3 changed files with 149 additions and 3 deletions

104
.gitea/workflows/build.yml Normal file
View File

@@ -0,0 +1,104 @@
name: Build and Release
on:
push:
branches: [master]
tags: ['v*']
jobs:
build-windows:
runs-on: windows-latest
defaults:
run:
shell: msys2 {0}
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Go
uses: actions/setup-go@v5
with:
go-version: '1.24'
cache: false
- name: Setup MSYS2
uses: msys2/setup-msys2@v2
with:
msystem: MINGW64
path-type: inherit
update: true
install: >-
mingw-w64-x86_64-gcc
mingw-w64-x86_64-opus
mingw-w64-x86_64-opusfile
mingw-w64-x86_64-portaudio
mingw-w64-x86_64-pkgconf
zip
- name: Build TUI
run: |
export CGO_ENABLED=1
mkdir -p dist
go build -o dist/ts3-tui.exe ./cmd/tui
# Copy DLLs
cp /mingw64/bin/libogg-0.dll dist/
cp /mingw64/bin/libopus-0.dll dist/
cp /mingw64/bin/libopusfile-0.dll dist/
cp /mingw64/bin/libportaudio-2.dll dist/ || true
# Create ZIP
cd dist && zip -r ../tui_windows_x86_64.zip . *
- name: Upload Artifact
uses: actions/upload-artifact@v3
with:
name: tui-windows-zip
path: tui_windows_x86_64.zip
build-linux:
runs-on: linux-x86_64
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Setup Go
uses: actions/setup-go@v5
with:
go-version: '1.24'
cache: false
- name: Install Dependencies
run: |
sudo apt-get update
sudo apt-get install -y \
libportaudio2 portaudio19-dev \
libopus-dev libopusfile-dev \
libpulse-dev pkg-config gcc
- name: Build TUI
run: |
export CGO_ENABLED=1
export ARCH=$(uname -m)
mkdir -p dist
go build -o dist/tui_linux_${ARCH} ./cmd/tui
- name: Upload Artifact
uses: actions/upload-artifact@v3
with:
name: tui-linux-binaries
path: dist/*
release:
needs: [build-windows, build-linux]
if: startsWith(github.ref, 'refs/tags/v')
runs-on: ubuntu-latest
steps:
- name: Download Artifacts
uses: actions/download-artifact@v3
- name: Create Release
uses: softprops/action-gh-release@v1
with:
files: |
tui-windows-zip/tui_windows_x86_64.zip
tui-linux-binaries/*
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}

View File

@@ -4,7 +4,8 @@ package main
import (
"os"
"syscall"
"golang.org/x/sys/unix"
)
func redirectStderr(f *os.File) {
@@ -12,12 +13,12 @@ func redirectStderr(f *os.File) {
// Silence altogether if no debug file
null, err := os.OpenFile(os.DevNull, os.O_WRONLY, 0)
if err == nil {
syscall.Dup2(int(null.Fd()), int(os.Stderr.Fd()))
_ = unix.Dup2(int(null.Fd()), int(os.Stderr.Fd()))
}
return
}
// Redirect fd 2 (stderr) to our debug file
// This captures C-level library noise (ALSA, PortAudio) into the log
syscall.Dup2(int(f.Fd()), int(os.Stderr.Fd()))
_ = unix.Dup2(int(f.Fd()), int(os.Stderr.Fd()))
}

View File

@@ -73,3 +73,44 @@ This project uses Go **build tags** to support multiple platforms from the same
### Pro Tip: VS Code Remote - WSL
For the best experience when working on Linux features from Windows, use the **WSL extension**. Open VS Code inside your WSL environment (`code .` from the WSL terminal). This allows `gopls` to run directly in Linux, where all system headers and libraries are natively available.
## 🤖 Gitea Actions (CI/CD)
El archivo `.gitea/workflows/build-windows.yml` automatiza la compilación en cada push.
### Cómo usar tu propio Windows como Runner
Si tu Gitea no tiene runners públicos, puedes convertir tu propia máquina Windows en uno:
1. **Descarga `act_runner`**: Descarga el binario oficial de [Gitea Actions Runner](https://gitea.com/gitea/act_runner/releases).
2. **Registro**:
- Ve a tu instancia de Gitea -> Administración del Sitio -> Actions -> Runners.
- Copia el **Registration Token**.
- Ejecuta: `./act_runner register`
- Introduce la URL de tu Gitea y el token.
- En **labels**, asegúrate de poner `windows-latest:host`.
3. **Ejecución**:
- Lanza el runner: `./act_runner daemon`.
- Ahora, cualquier push lanzará la build en tu PC de forma automática.
> [!TIP]
> El workflow usa **MSYS2** automáticamente para instalar `opus` y `portaudio` en el entorno temporal de la build, así que no necesitas configurar nada extra en el sistema del runner.
### Cómo añadir un Runner en WSL2 (para x86_64)
Si tu runner principal es ARM (como una Raspberry Pi) y quieres compilar para tu PC (x86_64), lo mejor es poner un runner dentro de WSL2:
1. **Entra en WSL2**: Ejecuta `wsl` en tu terminal.
2. **Descarga `act_runner`**:
```bash
curl -L https://gitea.com/gitea/act_runner/releases/download/v0.2.13/act_runner-0.2.13-linux-amd64 -o act_runner
chmod +x act_runner
```
3. **Registro**:
- Igual que en Windows, usa `./act_runner register` con el token de tu Gitea.
- En **labels**, pon algo como `linux-x86_64:host`.
4. **Actualiza el workflow**:
- En `.gitea/workflows/build-linux.yml`, cambia `runs-on: ubuntu-latest` por `runs-on: linux-x86_64`.
> [!NOTE]
> Al usar el label `:host`, el runner usará las herramientas instaladas en tu Linux de WSL2 sin necesidad de Docker, lo que lo hace mucho más rápido.