É necessário um editor PO para editar os arquivos de tradução. Este exemplo utiliza o editors/poedit.
# pkg install poedit
Capítulo 9. Traduções PO
Esta tradução pode estar desatualizada. Para ajudar com as traduções, acesse a ferramenta de traduções do FreeBSD.
Índice
9.1. Introdução
O GNU gettext oferece aos tradutores uma maneira fácil de criar e manter traduções de documentos. Sequências traduzíveis são extraídas do documento original em um arquivo PO (Portable Object). Versões traduzidas das strings são inseridas com um editor separado. As strings podem ser usadas diretamente ou incorporadas em uma versão traduzida completa do documento original.
9.2. Introdução
Supõe-se que o procedimento mostrado no Quick Start já tenha sido executado. A opção TRANSLATOR
é necessária e já está ativada por padrão no port textproc/docproj.
Este exemplo mostra a criação de uma tradução em Espanhol do pequeno artigo Leap Seconds.
Quando uma nova tradução é criada pela primeira vez, a estrutura do diretório e o Makefile devem ser criados ou copiados do original em Inglês:
Crie um diretório para a nova tradução. O código fonte do artigo em Inglês está em ~/doc/documentation/content/en/articles/leap-seconds/. A tradução em Espanhol estará em ~/doc/documentation/content/es/articles/leap-seconds/. O caminho é o mesmo, exceto pelo nome do diretório de idiomas.
% mkdir ~/doc/documentation/content/es/articles/leap-seconds
Copie o _index.po do documento original para o diretório de tradução:
% cp ~/doc/documentation/content/en/articles/leap-seconds/_index.po \ ~/doc/documentation/content/es/articles/leap-seconds/
Supondo que o documento ou idioma também esteja sendo traduzido via Weblate. Nesse caso, é bom pegar o arquivo .po
de lá e carregar o documento de tradução de volta na plataforma, centralizando os esforços de tradução via Weblate para evitar retrabalho.
Veja como baixar os arquivos .po
no capítulo Traduzindo Offline no Weblate.
Use um editor PO para inserir as traduções no arquivo PO. Existem vários editores diferentes disponíveis. O poedit do editors/poedit é mostrado aqui.
% poedit documentation/content/es/articles/leap-seconds/_index.po
Gere o documento traduzido:
% cd ~/doc % ./tools/translate.sh documentation es articles/leap-seconds
O nome do documento gerado corresponde ao nome do original em Inglês, geralmente _index.adoc.
Verifique o arquivo gerado renderizando-o para HTML e exibindo-o com um navegador web:
% cd ~/doc/documentation % make
9.3. Criando Novas Traduções
O primeiro passo para criar um novo documento traduzido é localizar ou criar um diretório para mantê-lo. O FreeBSD coloca documentos traduzidos em um subdiretório nomeado para seu idioma e região no formato lang . lang é um código minúsculo de dois caracteres.
Idioma | Região | Nome do Diretório da Tradução |
---|---|---|
English | United States | en |
Bengali | Bangladesh | bn-bd |
Danish | Denmark | da |
German | Germany | de |
Greek | Greece | el |
Spanish | Spain | es |
French | France | fr |
Hungarian | Hungary | hu |
Italian | Italy | it |
Japanese | Japan | ja |
Korean | Korea | ko |
Mongolian | Mongolia | mn |
Dutch | Netherlands | nl |
Polish | Poland | pl |
Portuguese | Brazil | pt-br |
Russian | Russia | ru |
Turkish | Turkey | tr |
Chinese | China | zh-cn |
Chinese | Taiwan | zh-tw |
As traduções estão em subdiretórios do diretório principal da documentação, aqui assumido como ~/doc/documentation/ como apresentado na Introdução. Por exemplo, as traduções em Alemão estão localizadas em ~/doc/documentation/content/de/ e as traduções em Francês estão em ~/doc/documentation/content/fr/.
Cada diretório de idiomas contém subdiretórios separados para os tipos de documentos, geralmente articles/ e books/.
A combinação desses nomes de diretórios fornece o caminho completo para um artigo ou livro. Por exemplo, a tradução Francesa do artigo NanoBSD está em ~/doc/documentation/content/fr/articles/nanobsd/, e a tradução em Mongol do manual está em ~/doc/documentation/content/mn/books/handbook/.
Um novo diretório de idioma deve ser criado ao traduzir um documento para um novo idioma. Se o diretório de idiomas já existir, somente um subdiretório no diretório articles/ ou books/ será necessário.
Crie uma nova tradução em Espanhol do Porter’s Handbook. O original é um livro em ~/doc/documentation/content/en/books/porters-handbook/.
O diretório de livros em Espanhol ~/doc/documentation/content/es/books/ já existe, portanto, apenas um novo subdiretório para o Porter’s Handbook é necessário:
% cd ~/doc/documentation/content/es/books % mkdir porters-handbook
Copie o conteúdo do livro original:
% cd porters-handbook % cp -R ~/doc/documentation/content/en/books/porters-handbook/* .
Agora a estrutura do documento está pronta para o tradutor começar a tradução com o
poedit
.
9.4. Traduzindo
O sistema gettext reduz bastante o número de itens que devem ser rastreados por um tradutor. As strings a serem traduzidas são extraídas do documento original em um arquivo PO. Em seguida, um editor PO é usado para inserir as traduções de cada string.
O sistema de tradução PO do FreeBSD não sobrescreve os arquivos PO, portanto a etapa de extração pode ser executada a qualquer momento para atualizar o arquivo PO.
Um editor PO é usado para editar o arquivo. editors/poedit é usado nestes exemplos porque é simples e tem requisitos mínimos. Outros editores PO oferecem recursos para facilitar o trabalho de tradução. A Coleção de Ports oferece vários desses editores, incluindo o devel/gtranslator.
É importante preservar o arquivo PO. Ele contém todo o trabalho que os tradutores fizeram.
Traduzir documentos online tende a ser o método mais fácil para tradução de documentos no FreeBSD, pois permite que vários usuários colaborem no mesmo arquivo, distribuindo a carga de trabalho de forma eficaz. Para obter mais detalhes, consulte o próximo capítulo, Traduções Weblate. |
9.5. Dicas para Tradutores
9.5.1. Preservando macros AsciiDoc
Preserve as macros AsciiDoc que são mostradas no original em Inglês.
Inglês original:
msgid "" "This example shows the creation of a Spanish translation of the short " "extref:{leap-seconds}[Leap Seconds] article."
Tradução para o Espanhol:
msgid "" "Este ejemplo muestra la creación de un artículo con poco contenido como el artículo " "extref:{leap-seconds}[Leap Seconds]."
9.6. Compilando um Documento Traduzido
Uma versão traduzida do documento original pode ser criada a qualquer momento. Quaisquer porções não traduzidas do original serão incluídas em Inglês no documento resultante. A maioria dos editores PO tem um indicador que mostra quanto da tradução foi realizada. Isso torna mais fácil para o tradutor ver quantas strings foram traduzidas para tornar a compilação do documento final utilizável.
O capítulo Weblate fornece um exemplo completo sobre Compilando o Documento Traduzido.
9.7. Submetendo a Nova Tradução
Prepare os novos arquivos de tradução para envio. Isso inclui adicionar os arquivos ao sistema de controle de versão, definir propriedades adicionais e criar um diff para a submissão.
Os arquivos diff criados por esses exemplos podem ser anexados a um relatório de bug de documentação ou revisão de código.
Crie um diff dos novos arquivos a partir do diretório base ~/doc/ para que o caminho completo seja mostrado com os nomes dos arquivos. Isso ajuda os committers a identificar o diretório do idioma de destino.
% cd ~/doc % git diff documentation/content/es/articles/nanobsd/ > /tmp/es_nanobsd.diff
O capítulo Weblate fornece um exemplo completo sobre Enviando Traduções.
Última alteração em: 9 de março de 2024 por Danilo G. Baio