|
Documentação
Marcar uma demonstraçãoPlataforma
PlataformaMCPCLIAPIWorkflows
GuiasChangelog

Localização contínua

  • Como funciona
  • Configuração

Plataformas

  • App GitHub
  • GitHub Actions
  • GitLab CI/CD
  • Bitbucket Pipelines
  • Padrões avançados

Padrões avançados

Padrões avançados de localização em CI/CD — escolha de workflow, verificação da completude das traduções e resolução de conflitos de merge.

Escolher um workflow#

Há quatro padrões de workflow que cobrem a maioria das configurações de equipa. Cada um implica diferentes compromissos ao nível da automação, do esforço de revisão e da higiene dos branches.

WorkflowIdeal paraCompromisso
Commit na mainEquipas pequenas, atualizações sem fricçãoSem etapa de revisão para as traduções
PR a partir da mainEquipas que querem rever as traduçõesRequer aprovação manual do PR
Commit no branch de funcionalidadeBranches de funcionalidade de longa duraçãoCommits de tradução no histórico do branch
PR a partir do branch de funcionalidadeControlo máximo por funcionalidadeVários PRs por funcionalidade para gerir

Se tiver dúvidas, comece por "Commit na main". É o workflow mais simples e evita por completo os conflitos de merge, já que não existe divergência entre branches.

Verificar se as traduções estão completas#

A flag --frozen verifica se todo o conteúdo está traduzido sem gerar novas traduções. Termina com um código de estado diferente de zero se houver conteúdo em falta:

bash
npx lingo.dev@latest run --frozen

Use isto como barreira de deployment para evitar lançar conteúdo por traduzir.

yaml
name: Check translations
on: [push, pull_request]
jobs:
  check:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v4
      - uses: actions/setup-node@v4
        with:
          node-version: 20
      - run: npx lingo.dev@latest run --frozen

Resolver conflitos de merge#

Os conflitos de merge surgem quando o ficheiro i18n.lock diverge entre branches — normalmente quando as traduções são atualizadas de forma independente em branches diferentes.

Prevenção#

Fazer commit das traduções diretamente em main (em vez de usar branches de funcionalidade para as traduções) elimina por completo os conflitos no lockfile.

Resolução por merge#

1

Iniciar o merge

bash
git merge <branch-name>
2

Eliminar o lockfile em conflito

bash
rm i18n.lock
3

Concluir o merge

bash
git add .
git merge --continue
4

Regenerar o lockfile

bash
npx lingo.dev@latest lockfile --force

Isto recria o lockfile a partir do estado atual dos seus ficheiros de origem sem acionar novas traduções.

Resolução por rebase#

A mesma abordagem funciona com rebase — elimine i18n.lock em cada etapa de conflito, continue o rebase e, no fim, regenere o lockfile:

bash
git rebase <branch-name>
# On each conflict: rm i18n.lock && git add . && git rebase --continue
npx lingo.dev@latest lockfile --force

Próximos passos#

GitHub Actions
Configure a GitHub Action oficial
i18n.lock
Como o lockfile acompanha o estado das traduções
Como funciona
O pipeline de localização em CI/CD
Configuração
Configure o CI/CD do seu projeto

Esta página foi útil?

Max PrilutskiyMax Prilutskiy·Atualizado há 4 meses·2 min de leitura