Pular para o conteúdo

Sistema de Build

O Wails oferece um sistema de build unificado que compila código Go, empaceta ativos do frontend, embute tudo em um único executável e lida com builds específicos de plataforma — tudo com um único comando.

Terminal window
wails3 build

Saída: Executável nativo com tudo embutido.

[Espaço Reservado para Diagrama do Processo de Build]

O Wails analisa seu código Go para entender seus serviços:

type GreetService struct {
prefix string
}
func (g *GreetService) Greet(name string) string {
return g.prefix + name + "!"
}

O que o Wails extrai:

  • Nome do serviço: GreetService
  • Nome do método: Greet
  • Tipos de parâmetro: string
  • Tipos de retorno: string

Usado para: Gerar bindings de TypeScript

O Wails gera bindings com tipagem segura:

frontend/bindings/GreetService.ts
export function Greet(name: string): Promise<string> {
return window.wails.Call('GreetService.Greet', name)
}

Benefícios:

  • Segurança de tipos completa
  • Autocompletar na IDE
  • Erros em tempo de compilação
  • Comentários JSDoc

Seu bundler de frontend é executado (Vite, webpack, etc.):

Terminal window
# Exemplo do Vite
vite build --outDir dist

O que acontece:

  • JavaScript/TypeScript compilado
  • CSS processado e minificado
  • Otimização de ativos
  • Mapas de origem gerados (apenas dev)
  • Saída para frontend/dist/

O código Go é compilado com otimizações:

Terminal window
go build -ldflags="-s -w" -o myapp.exe

Flags:

  • -s: Remove a tabela de símbolos
  • -w: Remove informações de depuração DWARF
  • Resultado: Binário menor (~30% de redução)

Específico da plataforma:

  • Windows: .exe com ícone embutido
  • macOS: Estrutura de bundle .app
  • Linux: Binário ELF

Os ativos do frontend são embutidos no binário Go:

//go:embed frontend/dist
var assets embed.FS

Resultado: Executável único com tudo dentro.

Único binário nativo:

  • Windows: myapp.exe (~15MB)
  • macOS: myapp.app (~15MB)
  • Linux: myapp (~15MB)

Sem dependências (exceto o WebView do sistema).

Otimizado para velocidade:

Terminal window
wails3 dev

O que acontece:

  1. Inicia o servidor de desenvolvimento do frontend (Vite na porta 5173)
  2. Compila o Go sem otimizações
  3. Inicia o aplicativo apontando para o servidor de desenvolvimento
  4. Habilita hot reload
  5. Inclui mapas de origem

Características:

  • Recompilações rápidas (<1s para alterações no frontend)
  • Sem embutimento de ativos (servidos pelo servidor de desenvolvimento)
  • Símbolos de depuração incluídos
  • Mapas de origem habilitados
  • Logs verbosos

Tamanho do arquivo: Maior (~50MB com símbolos de depuração)

Terminal window
wails3 build

Saída: build/bin/myapp[.exe]

Terminal window
# Build para Windows (de qualquer OS)
wails3 build -platform windows/amd64
# Build para macOS
wails3 build -platform darwin/amd64
wails3 build -platform darwin/arm64
# Build para Linux
wails3 build -platform linux/amd64

Compilação cruzada: Compile para qualquer plataforma a partir de qualquer plataforma.

Terminal window
# Diretório de saída personalizado
wails3 build -o ./dist/myapp
# Pular build do frontend (usar existente)
wails3 build -skipbindings
# Build limpo (remover cache)
wails3 build -clean
# Saída verbosa
wails3 build -v
Terminal window
# Build de depuração (inclui símbolos)
wails3 build -debug
# Build de produção (padrão, otimizado)
wails3 build
# Build de desenvolvimento (rápido, não otimizado)
wails3 build -devbuild

O Wails usa Taskfile para configuração de build:

Taskfile.yml
version: '3'
tasks:
build:
desc: Build the application
cmds:
- wails3 build
build:windows:
desc: Build for Windows
cmds:
- wails3 build -platform windows/amd64
build:macos:
desc: Build for macOS (Universal)
cmds:
- wails3 build -platform darwin/amd64
- wails3 build -platform darwin/arm64
- lipo -create -output build/bin/myapp.app build/bin/myapp-amd64.app build/bin/myapp-arm64.app
build:linux:
desc: Build for Linux
cmds:
- wails3 build -platform linux/amd64

Executar tarefas:

Terminal window
task build:windows
task build:macos
task build:linux

Crie build/build.json para configuração persistente:

{
"name": "My Application",
"version": "1.0.0",
"author": "Your Name",
"description": "Application description",
"icon": "build/appicon.png",
"outputFilename": "myapp",
"platforms": ["windows/amd64", "darwin/amd64", "linux/amd64"],
"frontend": {
"dir": "./frontend",
"install": "npm install",
"build": "npm run build",
"dev": "npm run dev"
},
"go": {
"ldflags": "-s -w -X main.version={{.Version}}"
}
}

O Wails usa o pacote embed do Go:

package main
import (
"embed"
"github.com/wailsapp/wails/v3/pkg/application"
)
//go:embed frontend/dist
var assets embed.FS
func main() {
app := application.New(application.Options{
Name: "My App",
Assets: application.AssetOptions{
Handler: application.AssetFileServerFS(assets),
},
})
app.Window.New()
app.Run()
}

No momento do build:

  1. Frontend construído em frontend/dist/
  2. Diretiva //go:embed inclui os arquivos
  3. Arquivos compilados no binário
  4. Binário contém tudo

Em tempo de execução:

  1. App inicia
  2. Ativos servidos da memória
  3. Sem E/S de disco para ativos
  4. Carregamento rápido

Incorpore arquivos adicionais:

//go:embed frontend/dist
var frontendAssets embed.FS
//go:embed data/*.json
var dataAssets embed.FS
//go:embed templates/*.html
var templateAssets embed.FS

Vite (padrão):

vite.config.js
export default {
build: {
minify: 'terser',
terserOptions: {
compress: {
drop_console: true, // Remove console.log
drop_debugger: true,
},
},
rollupOptions: {
output: {
manualChunks: {
vendor: ['react', 'react-dom'], // Separa bundle de vendor
},
},
},
},
}

Resultados:

  • JavaScript minificado (~70% de redução)
  • CSS minificado (~60% de redução)
  • Imagens otimizadas
  • Tree-shaking aplicado

Flags do compilador:

Terminal window
-ldflags="-s -w"
  • -s: Remove tabela de símbolos (~10% de redução)
  • -w: Remove informações de depuração DWARF (~20% de redução)

Otimizações adicionais:

Terminal window
-ldflags="-s -w -X main.version=1.0.0"
  • -X: Define valores de variáveis no momento do build
  • Útil para números de versão, datas de build

UPX (opcional):

Terminal window
# Após o build
upx --best build/bin/myapp.exe

Resultados: