Locale::Po4a::Man(3pm) | Ferramentas do Po4a | Locale::Po4a::Man(3pm) |
Locale::Po4a::Man - converte páginas de manual de/para arquivos PO
O objetivo do projeto po4a (PO for anything, ou PO para qualquer coisa) é facilitar traduções (e o mais interessante, a manutenção das traduções) usando as ferramentas do gettext em áreas em que não se esperava, como documentação.
Locale::Po4a::Man é um módulo para ajudar a tradução de documentação no formato nroff (o idioma das páginas de manual) para outros idiomas.
Este módulo tenta com muito esforço tornar a vida do tradutor mais fácil. Para isso, o texto apresentado para os tradutores não é uma cópia exata do texto encontrado na página de manual. Exatamente: as partes mais cruas do formato nroff são ocultadas de forma que os tradutores não possam se complicar com elas.
Parágrafos sem recuo são automaticamente redimensionados para o tradutor. Isso pode levar a alguma pequena diferença no resultado gerado, já que regras de redimensionamento usadas pelo groff não são muito claras. Por exemplo, dois espaços após um parêntese é mantido em alguns casos.
De qualquer forma, a diferença será apenas sobre a posição de espaços extras em parágrafos dimensionados, e eu acho que isso vale a pena.
A primeira alteração é sobre especificação de alteração de fontes. No nroff, há várias formas de especificar se uma palavra fornecida deveria ser escrita diminuída, negrito ou itálico. No texto para traduzir, há apenas uma forma, emprestada do formato POD (documentação on-line do Perl):
Observação: A opção CW não está disponível para todos os dispositivos groff. Não é recomendável usá-lo. Ele é fornecido para sua conveniência.
Po4a translitera automaticamente alguns caracteres para facilitar a tradução ou a revisão da tradução. Aqui está a lista de transliterações:
Tradutores podem forçar um hífen usando o glifo "\[hy]" do roff em suas traduções.
Para evitar essas transliterações, os tradutores podem inserir um caractere roff com zero de largura (isto é, usando `\&` ou '\&', respectivamente).
Já que esses caracteres são usados para delimitar partes sob modificação de fonte, você não pode usá-los literalmente. Use E<lt> e E<gt> em vez disso (como em POD, novamente).
Estas são as opções específicas deste módulo:
Ela seleciona um suporte mais estrito ao formato mdoc ao informar po4a que não deve traduzir a seção "NAME". Páginas mdoc cuja seção "NAME" está traduzida não vão gerar cabeçalho ou nota de rodapé algum.
De acordo com as páginas do groff_mdoc, as
seções NAME, SYNOPSIS e DESCRIPTION são
obrigatórias. Não há problemas conhecidos com
seções SYNOPSIS ou DESCRIPTION traduzidas, mas você
também pode especificar essas seções desta forma:
-o mdoc=NAME,SYNOPSIS,DESCRIPTION
Esse problema pode ser resolvido com um adendo como este aqui:
PO4A-HEADER:mode=before;position=^.Dd
.TH DOCUMENT_TITLE 1 "dia mês, ano" OS "Nome da
seção"
As opções a seguir permitem especificar o comportamento de uma nova macro (definida com uma requisição .de) ou de uma macro sem suporte pelo po4a. Elas levam como argumento uma lista separada por vírgula de macros. Por exemplo:
-o noarg=FO,OB,AR -o translate_joined=BA,ZQ,UX
Nota: se uma macro não tem suporte no po4a e se você considera que é uma macro roff padrão, você deveria enviá-la para a equipe de desenvolvimento do po4a.
Nota: nenhum teste é feito para assegurar que um comando end corresponde ao seu comando begin; qualquer comando de finalização termina o modo no_wrap. Se você tem uma macro begin (respectivamente end) que não possui end (respectivamente begin), você pode especificar uma end existente (como fi) ou begin (como nf) como uma contraparte. Essas macros (e seus argumentos) não serão traduzidos.
Este módulo ainda é bem limitado, e sempre será, pois ele não é um interpretador nroff de verdade. Seria possível criar um interpretador nroff para permitir que autores usem todas as macros existentes ou até mesmo definir novas em suas páginas, mas nós não queríamos. Seria muito difícil e nós entendemos não haver necessidade. Nós pensamos que se os autores de páginas de manual desejam ver seus produtos traduzidos, eles podem ter que adaptar para facilitar o trabalho dos tradutores.
Então, o analisador de manuais implementado no po4a possui algumas limitações conhecidas que nós não exatamente estamos podendo corrigir e que podem ser buracos a serem evitados se você não quiser ver tradutores tomando conta da sua documentação.
nroff é uma linguagem de programação completa, com definição de macros, condicionais e por aí vai. Já que este analisador não é um interpretador nroff com todas suas funcionalidades, ela vai falhar em páginas usando essas capacidades (Há cerca de 200 de tais páginas no meu computador).
Há ainda algumas macros que não encontram suporte no po4a::man. Isso porque eu não consegui encontrar qualquer documentação sobre elas. Aqui está a lista de macros sem suporte, usadas na minha máquina. Note que essa lista não é exaustiva, já que o programa falha na primeira macro sem suporte encontrada. Se você não possui qualquer informação sobre algumas dessas macros, ficarei feliz em adicionar suporte a elas. Por causa dessas macros, cerca de 250 páginas estão inacessíveis para po4a::man.
.. ." .AT .b .bank .BE ..br .Bu .BUGS .BY .ce .dbmmanage .do .En .EP .EX .Fi .hw .i .Id .l .LO .mf .N .na .NF .nh .nl .Nm .ns .NXR .OPTIONS .PB .pp .PR .PRE .PU .REq .RH .rn .S< .sh .SI .splitfont .Sx .T .TF .The .TT .UC .ul .Vb .zZ
Algumas vezes, o autor sabe que algumas partes não são traduzíveis e, portanto, não deveriam ser extraídas pelo po4a. Por exemplo, uma opção pode aceitar um argumento other e other também pode aparecer como o último item de uma lista. No primeiro caso, other não deveria ser traduzível. e no segundo caso, other deveria ser traduzido.
Neste aso, o autor pode evitar que po4a extraia algumas strings usando alguns constructs especiais do groff:
.if !'po4a'hide' .B other
(isto vai exibir a opção -o groff_code=verbatim)
Uma nova macro também pode ser definida para automatizar
isso:
.de IR_untranslated
. IR \\$@
..
.IR_untranslated \-q ", " \-\-quiet
(Isto vai exigir as opções -o groff_code=verbatim e -o untranslated=IR_untranslated; com este construct, a condicional .if !'po4a'hide' não é estritamente necessária já que po4a não vai analisar o interno da definição de macro)
ou usando o alias:
.als IR_untranslated IR
.IR_untranslated \-q ", " \-\-quiet
Isto vai exigir a opção -o untranslated=als,IR_untranslated.
Para resumir esta seção, mantenha simples e não tente ser esperto ao criar suas páginas de manual. Muitas coisas são possível no nroff, mas que não têm suporte neste analisador. Por exemplo, não tente bagunçar o \c interrompendo o processamento de texto (como 40 páginas na minha máquina fazem). Ou, certifique-se de que colocar os argumentos de macros na mesma linha da própria macro. Eu se que é válido no nroff, mas complicado demais para o analisador lidar.
É claro, outra possibilidade é usar outro formato, mais amigável ao tradutor (como POD usando po4a::pod ou um da família XML como o SGML), mas graças ao po4a::man isso não é mais necessário. Tendo dito isso, se o formato fonte da documentação é POD, ou XML, pode ser inteligente traduzir o formato fonte e não este gerado. Na maioria dos casos, po4a::man vai detectar páginas geradas e mostrar um aviso. El vai até mesmo recusar processar páginas geradas no POD porque tais páginas são lidadas perfeitamente pelo po4a::pod, e porque sua contraparte nroff define um monte de novas macros que eu não desejo dar suporte. Na minha máquina, 1432 das 4323 página são geradas de POD e vão ser ignoradas pelo po4a::man.
Na maioria dos casos, po4a::man vai detectar o problema e se recusar a processar a página, apresentando uma mensagem adaptada. Em alguns casos raros, o programa vai completar sem avisos, mas a saída estará errada. Tais casos são chamados de "bugs" ;) Se você encontrar tal caso, certifique-se de relatá-lo, junto com uma solução, quando possível…
Este módulo pode ser usado para a maioria das páginas de manual existentes.
Alguns testes são executados frequentemente em máquinas Linux:
Locale::Po4a::Pod(3pm), Locale::Po4a::TransTractor(3pm), po4a(7)
Denis Barbier <barbier@linuxfr.org> Nicolas François <nicolas.francois@centraliens.net> Martin Quinson (mquinson#debian.org)
Copyright © 2002-2008 SPI, Inc.
Esse programa é um software livre; você pode redistribuí-lo e/ou modificá-lo sob os termos da GPL (veja o arquivo COPYING).
2018-12-09 | Ferramentas do Po4a |