.\" -*- mode: troff; coding: utf-8 -*- .\" Automatically generated by Pod::Man 5.01 (Pod::Simple 3.43) .\" .\" Standard preamble: .\" ======================================================================== .de Sp \" Vertical space (when we can't use .PP) .if t .sp .5v .if n .sp .. .de Vb \" Begin verbatim text .ft CW .nf .ne \\$1 .. .de Ve \" End verbatim text .ft R .fi .. .\" \*(C` and \*(C' are quotes in nroff, nothing in troff, for use with C<>. .ie n \{\ . ds C` "" . ds C' "" 'br\} .el\{\ . ds C` . ds C' 'br\} .\" .\" Escape single quotes in literal strings from groff's Unicode transform. .ie \n(.g .ds Aq \(aq .el .ds Aq ' .\" .\" If the F register is >0, we'll generate index entries on stderr for .\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index .\" entries marked with X<> in POD. Of course, you'll have to process the .\" output yourself in some meaningful fashion. .\" .\" Avoid warning from groff about undefined register 'F'. .de IX .. .nr rF 0 .if \n(.g .if rF .nr rF 1 .if (\n(rF:(\n(.g==0)) \{\ . if \nF \{\ . de IX . tm Index:\\$1\t\\n%\t"\\$2" .. . if !\nF==2 \{\ . nr % 0 . nr F 2 . \} . \} .\} .rr rF .\" ======================================================================== .\" .IX Title "PO4A.1P 1" .TH PO4A.1P 1 2024-06-26 "perl v5.38.2" "User Contributed Perl Documentation" .\" For nroff, turn off justification. Always turn off hyphenation; it makes .\" way too many mistakes in technical documents. .if n .ad l .nh .SH NOMBRE .IX Header "NOMBRE" po4a \- Actualiza los ficheros PO y los documentos traducidos a la vez .SH SINOPSIS .IX Header "SINOPSIS" \&\fBpo4a\fR [\fIopciones\fR] \fIfichero_de_configuración\fR .SH DESCRIPCIÓN .IX Header "DESCRIPCIÓN" po4a (PO para cualquier cosa) facilita el mantenimiento de la traducción de documentación utilizando las herramientas clásicas de gettext. La característica principal de po4a es que desacopla la traducción del contenido de la estructura del documento. Consulte la página po4a (7) para obtener una breve introducción a este proyecto. .PP Al ejecutarse, \fBpo4a\fR analiza todos los archivos de documentación especificados en su fichero de configuración. Actualiza los archivos PO (que contienen la traducción) para reflejar cualquier cambio en la documentación, y produce los documentos traducidos inyectando la traducción del contenido (que se encuentra en los archivos PO) en la estructura del documento maestro original. .PP Inicialmente, los archivos PO solo contienen las cadenas a traducir de la documentación original. Este formato de archivo permite a los traductores proporcionar manualmente una traducción para cada párrafo extraído por \fBpo4a\fR. Si la documentación se modifica posteriormente a la traducción, \fBpo4a\fR marca las traducciones correspondientes como "fuzzy" en el archivo PO para solicitar una revisión manual por parte de los traductores. Los traductores también pueden proporcionar un "anexo"; contenido extra que por ejemplo puede informar de quién realizó la traducción y cómo reportar fallos. .PP .Vb 11 \& documentos maestros \-+\-\-\-\->\-\-\-\-\-\-\-\->\-\-\-\-\-\-\-\-\-+ \& (autoria doc) | | \& V (ejecuciones po4a) >\-\-\-\-\-+\-\-> documentos \& | | | traducidos \&archivo PO existente\->\-\-> PO actualizados >\-+ | \& ^ | | \& | V | \& +\-\-\-\-\-\-\-\-\-\-<\-\-\-\-\-\-\-\-\-<\-\-\-\-\-\-\-+ ^ \& (proceso de traducción manual) | \& | \& anexo \-\->\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-+ .Ve .PP El flujo de trabajo de \fBpo4a\fR es asíncrono, como corresponde a los proyectos de código abierto. Los redactores de la documentación crean los documentos maestros a su propio ritmo. Los traductores revisan y actualizan las traducciones en los archivos PO. Los mantenedores vuelven a ejecutar \fBpo4a\fR cuando es necesario, para reflejar cualquier cambio en la documentación original en los archivos PO, y para producir traducciones actualizadas de la documentación, inyectando la última traducción en la última estructura del documento. .PP Por defecto, un documento traducido se produce cuando al menos el 80% de su contenido está traducido. El texto no traducido se mantiene en el idioma original. De este modo, la documentación producida mezcla idiomas si la traducción no es completa. Puede modificar el umbral del 80% con la opción \fI\-\-keep\fR que se describe abajo. Tenga en cuenta, sin embargo, que descartar traducciones en cuanto no están al 100% puede ser desalentador para los traductores, cuyo trabajo casi nunca se mostrará a los usuarios, mientras que mostrar "traducciones" demasiado incompletas puede ser problemático para los usuarios finales. .PP Almacenar los archivos de documentación traducidos en el sistema de control de versiones es probablemente una mala idea, ya que se generan automáticamente. Los archivos valiosos son los archivos PO, que contienen el duro trabajo de los compañeros traductores. Además, a algunas personas les resulta más fácil interactuar con los traductores a través de una plataforma en línea como weblate, pero naturalmente esto es totalmente opcional. .SS "Tutorial de iniciación rápida" .IX Subsection "Tutorial de iniciación rápida" Supongamos que usted mantiene un programa llamado \fBfoo\fR que tiene una página de manual \fIman/foo.1\fR escrita en inglés (el idioma puente en la mayoría de los proyectos de código abierto, pero \fBpo4a\fR puede usarse desde o hacia cualquier idioma). Hace algún tiempo, alguien proporcionó una traducción al alemán llamada \fIman/foo.de.1\fR y desapareció. Esto es un problema porque usted acaba de recibir un informe de error diciendo que su documentación contiene una información gravemente errónea que debe ser corregida en todos los idiomas, pero usted no habla alemán, así que sólo puede modificar el original, no la traducción. Ahora, otro colaborador quiere aportar una traducción al japonés, un idioma que usted tampoco domina. .PP Es hora de convertir su documentación a \fBpo4a\fR para solucionar sus pesadillas de mantenimiento de la documentación. Quiere actualizar la documentación cuando sea necesario, quiere facilitar el trabajo de sus compañeros traductores y quiere asegurarse de que sus usuarios nunca vean documentación obsoleta y, por tanto, errónea. .PP La conversión incluye dos pasos: configurar la infraestructura po4a, y convertir la traducción anterior al alemán para salvar el trabajo previo. Esta última parte se hace usando po4a\-gettextize, como sigue. Como se detalla en la documentación de \fBpo4a\-gettextize\fR\|(1), este proceso raramente es completamente automático, pero una vez hecho, el archivo \fBde.po\fR que contiene la traducción al alemán puede integrarse en su flujo de trabajo con po4a. .PP .Vb 1 \& po4a\-gettextize \-\-format man \-\-master foo.1 \-\-localized foo.de.1 \-\-po de.po .Ve .PP Configuremos ahora po4a. Con el diseño de archivo apropiado, su archivo de configuración podría ser tan simple como esto: .PP .Vb 1 \& [po_directory] man/po4a/ \& \& [type: man] man/foo.1 $lang:man/translated/foo.$lang.1 .Ve .PP Especifica que todos los archivos PO (que contienen el trabajo de los traductores) están en el directorio \fIman/po4a/\fR, y que solo tiene un archivo maestro, \fIman/foo.1\fR. Si tuvieras varios archivos maestros, tendrías varias líneas similares a la segunda. Cada una de estas líneas también especifica dónde escribir los archivos de traducción correspondientes. Aquí, la traducción alemana de \fIman/foo.1\fR está en \fIman/translated/foo.de.1\fR. .PP Lo último que necesitamos para completar la configuración de \fBpo4a\fR es un archivo POT que contenga el material de plantilla que debe utilizarse para iniciar una nueva traducción. Basta con crear un archivo vacío con la extensión .pot en el po_directory especificado (por ejemplo, \fIman/po4a/foo.pot\fR), y \fBpo4a\fR lo rellenará con el contenido esperado. .PP Aquí tiene un resumen de los archivos en esta configuración: .PP .Vb 7 \& ├── man/ \& │ ├── foo.1 <\- La página de manual original, en inglés \& │ ├── po4a/ \& │ │ ├── de.po <\- La traducción de PO al alemán, de gettextization \& │ │ └── foo.pot <\- La plantilla POT de futuras traducciones (vacía al principio) \& │ └── traducido/ <\- Directorio donde se crearán las traducciones \& └── po4a.cfg <\- El fichero de configuración .Ve .PP Una vez configurado, ejecutando \fBpo4a\fR analizará su documentación, actualizará la plantilla POT, lo usará para actualizar los archivos de traducción PO, y los usará para actualizar los archivos de traducción de la documentación. Todo en un solo comando: .PP .Vb 1 \& po4a \-\-verbose po4a.cfg .Ve .PP Esto es. \fBpo4a\fR ya está completamente configurado. Una vez que hayas corregido tu error en \fIman/foo.1\fR, el párrafo ofensivo en la traducción al alemán será reemplazado por el texto corregido en inglés. Mezclar idiomas no es óptimo, pero es la única manera de eliminar errores en las traducciones que ni siquiera entiendes, y asegurarte de que el contenido presentado a los usuarios nunca sea engañoso. Actualizar la traducción al alemán también es mucho más fácil en el archivo PO correspondiente, por lo que es posible que la confusión de idiomas no dure mucho. Por último, cuando un traductor de japonés quiera contribuir con una nueva traducción, debe cambiar el nombre de foo.pot a ja.po y completar la traducción. Una vez que tengas este archivo, simplemente suéltalo en \fIman/po4a/po/\fR. Una página traducida aparecerá como \fIman/translated/foo.ja.1\fR (siempre que se traduzca suficiente contenido) cuando vuelva a ejecutar \fBpo4a\fR. .SH OPCIONES .IX Header "OPCIONES" .IP "\fB\-k\fR, \fB\-\-keep\fR" 4 .IX Item "-k, --keep" El umbral mínimo del porcentaje de traducción para preservar (es decir, escribir) el archivo resultante (predefinido: 80). Es decir, por defecto los archivos deben estar traducidos como mínimo en un 80% para que se escriban en el disco. .IP "\fB\-w\fR, \fB\-\-width\fR" 4 .IX Item "-w, --width" Columna en la que debemos ajustar el archivo resultante si el formato lo admite (predeterminado: 76). .IP "\fB\-h\fR, \fB\-\-help\fR" 4 .IX Item "-h, --help" Muestra un mensaje corto de ayuda. .IP "\fB\-M\fR, \fB\-\-master\-charset\fR" 4 .IX Item "-M, --master-charset" El juego de caracteres de los ficheros que contienen los documentos a traducir. Tenga en cuento que todos los documentos maestros deben usar el mismo juego de caracteres. .IP "\fB\-L\fR, \fB\-\-localized\-charset\fR" 4 .IX Item "-L, --localized-charset" El juego de caracteres de los ficheros que contienen los documentos localizados. Tenga en cuentao que todos los documentos traducidos deben usar el mismo juego de caracteres. .IP "\fB\-A\fR, \fB\-\-addendum\-charset\fR" 4 .IX Item "-A, --addendum-charset" El juego de caracteres del apéndice. Todos los apéndices deben usar el mismo juego de caracteres. .IP "\fB\-V\fR, \fB\-\-version\fR" 4 .IX Item "-V, --version" Muestra la versión del script y cierra. .IP "\fB\-v\fR, \fB\-\-verbose\fR" 4 .IX Item "-v, --verbose" Aumenta la cantidad de mensajes informativos del programa. .IP "\fB\-q\fR, \fB\-\-quiet\fR" 4 .IX Item "-q, --quiet" Disminuye la cantidad de mensajes informativos del programa. .IP "\fB\-d\fR, \fB\-\-debug\fR" 4 .IX Item "-d, --debug" Devuelve por la salida información de depuración de fallos. .IP "\fB\-o\fR, \fB\-\-option\fR" 4 .IX Item "-o, --option" Opción(es) adicionales a introducir a la extensión del formato. Consulte la documentación de cada extensión para más información acerca de las opciones aceptadas y su significado. Por ejemplo, puede pasar '\-o tablecells' al intérprete AsciiDoc, mientras que el intérprete de texto aceptaría '\-o tabs=split'. .IP "\fB\-f\fR, \fB\-\-force\fR" 4 .IX Item "-f, --force" Siempre genera los ficheros POT y PO, incluso si \fBpo4a\fR no lo considera necesario. .Sp El comportamiento predefinido (cuando no se especifica \fB\-\-force\fR) es el siguiente: .RS 4 .Sp .RS 4 Si ya existe el fichero POT, se generará otra vez si el documento original o el fichero de configuración es más reciente (a menos que se de \fB\-\-no\-update\fR). El fichero POT se escribe también en un documento temporal y \fBpo4a\fR comprueba si los cambios son realmente necesarios. .Sp Así mismo, una traducción se genera otra vez sólo si el documento original, el fichero PO, uno de sus apéndices o el fichero de configuración son más recientes. Para evitar generar otra vez las traducciones que no pasan el análisis del umbral (consulte \fB\-\-keep\fR), puede crear un fichero con la extensión \fI.po4a\-stamp\fR (consulte ). .RE .RE .RS 4 .Sp Debería usar la marca \fB\-\-force\fR si el documento original incluye ficheros, ya que no se toma en cuenta la fecha de modificación de estos ficheros incluidos. .Sp Los ficheros PO siempre se regeneran en base al POT con \fBmsgmerge \-U\fR. .RE .IP \fB\-\-stamp\fR 4 .IX Item "--stamp" Activa la creación de ficheros de marcas («stamp files») cuando no se ha generado una traducción al no alcanzar éste el umbral. Estos ficheros de marcas se nombran de acuerdo al documento traducido esperado, con la extensión \fI.po4a\-stamp\fR. .Sp Nota: Esto sólo activa la creación de ficheros \fI.po4a\-stamp\fR. En caso de existir siempre se usarán estos ficheros, y se eliminan con \fB\-\-rm\-translations\fR o cuando el fichero está completamente traducido. .IP \fB\-\-no\-translations\fR 4 .IX Item "--no-translations" No genera los documentos traducidos, sólo actualiza los ficheros POT y PO. .IP \fB\-\-no\-update\fR 4 .IX Item "--no-update" Impide modificar los ficheros POT y PO, solo se actualiza la traducción. .IP \fB\-\-keep\-translations\fR 4 .IX Item "--keep-translations" Preserva los ficheros traducidos existentes incluso si la traducción no satisface el umbral especificado por \fB\-\-keep\fR. Esta opción no crea ficheros traducidos nuevos con escaso contenido, pero guarda las traducciones existentes incompletas debido a cambios en los ficheros originales. .Sp ADVERTENCIA: Esta opción modifica el comportamiento de po4a de forma muy notable: los ficheros traducidos no se actualizan en absoluto hasta mejorar la traducción. Utilice esta opción solo en caso de preferir la distribución de documentación traducida anticuada en lugar de distribuir una documentación no traducida precisa. .IP \fB\-\-rm\-translations\fR 4 .IX Item "--rm-translations" Elimina los ficheros traducidos (implica \fB\-\-no\-translations\fR). .IP \fB\-\-no\-backups\fR 4 .IX Item "--no-backups" A partir de la versión 0.41, esta opción no tiene ningún efecto. Puede que se elimine en alguna futura publicación. .IP \fB\-\-rm\-backups\fR 4 .IX Item "--rm-backups" A partir de la versión 0.41, esta opción no tiene ningún efecto. Puede que se elimine en alguna futura publicación. .IP "\fB\-\-translate\-only\fR \fIfichero-traducido\fR" 4 .IX Item "--translate-only fichero-traducido" Traduce sólo el fichero especificado. Puede ser útil para agilizar el proceso si el fichero de configuración contiene muchos ficheros. Tenga en cuenta que esta opción no actualiza los ficheros PO y POT. Puede usar esta opción varias veces. .IP "\fB\-\-variable\fR \fIvar\fR\fB=\fR\fIvalor\fR" 4 .IX Item "--variable var=valor" Define una variable que se expandirá en el fichero de configuración de \fBpo4a\fR. Cada aparición de \fI$(var)\fR se reemplazará por \fIvalor\fR. Puede introducir está opción varias veces. .IP "\fB\-\-srcdir\fR \fISRCDIR\fR" 4 .IX Item "--srcdir SRCDIR" Define el directorio base de todos los documentos de entrada especificados en el fichero de configuración de \fBpo4a\fR. .Sp Si se especifican tanto \fIdestdir\fR como \fIsrcdir\fR, los archivos de entrada se buscan en los siguientes directorios, en orden: \fIdestdir\fR, el directorio actual y \fIsrcdir\fR. Los archivos de salida se escriben en \fIdestdir\fR si se especifica, o en el directorio actual. .IP "\fB\-\-destdir\fR \fIDESTDIR\fR" 4 .IX Item "--destdir DESTDIR" Define el directorio base de todos los documentos de salida especificados en el fichero de configuración de \fBpo4a\fR (ver \fB\-\-srcdir\fR). .SS "Opciones que modifican el encabezado POT" .IX Subsection "Opciones que modifican el encabezado POT" .IP "\fB\-\-porefs\fR \fItype\fR" 4 .IX Item "--porefs type" Define el forma de referencia: El argumento \fItype\fR puede ser \fBnever\fR para no generar ninguna referencia, \fBfile\fR para solo especificar el fichero el número de línea, \fBcounter\fR para sustituir el número de línea con un recuento ascendente, y \fBfull\fR para incluir referencias completas (predefinido: full). .IP "\fB\-\-wrap\-po\fR \fBno\fR|\fBnewlines\fR|\fInumber\fR (por omisión: 76)" 4 .IX Item "--wrap-po no|newlines|number (por omisión: 76)" Especifique cómo se debe ajustar el archivo po. Esto permite elegir entre archivos que están bien ajustados pero que podrían generar conflictos de git o archivos que son más fáciles de manejar automáticamente, pero más difíciles de leer para los humanos. .Sp Históricamente, la suite gettext ha reformateado los archivos po en la columna 77 por razones cosméticas. Esta opción especifica el comportamiento de po4a. Si se establece en un valor numérico, po4a ajustará el archivo po después de esta columna y después de nuevas líneas en el contenido. Si se establece en \fBnewlines\fR, po4a solo dividirá los msgid y msgstr después de nuevas líneas en el contenido. Si se establece en \fBno\fR, po4a no ajustará el archivo po en absoluto. Los comentarios de referencia siempre son ajustados por las herramientas gettext que usamos internamente. .Sp Tenga en cuenta que esta opción no tiene ningún impacto en cómo se ajustan msgid y msgstr, es decir, en cómo se agregan nuevas líneas al contenido de estas cadenas. .IP \fB\-\-master\-language\fR 4 .IX Item "--master-language" El idioma de los ficheros que contienen el documento a traducir. Todos los documentos maestros deben utilizar el mismo idioma. .IP "\fB\-\-msgid\-bugs\-address\fR \fIcorreo\-e@direccion\fR" 4 .IX Item "--msgid-bugs-address correo-e@direccion" Define el destinatario de los informes de fallo en los msgid. Por omisión, los ficheros POT creados no tienen el campo «Report\-Msgid\-Bugs\-To». .IP "\fB\-\-copyright\-holder\fR \fIcadena\fR" 4 .IX Item "--copyright-holder cadena" Define el titula de los derechos de reproducción en la cabecera del POT. El valor predefinido es «Free Software Foundation, Inc.» .IP "\fB\-\-package\-name\fR \fIstring\fR" 4 .IX Item "--package-name string" Define el nombre del paquete en la cabecera del POT. El valor por omisión es «PACKAGE». .IP "\fB\-\-package\-version\fR \fIstring\fR" 4 .IX Item "--package-version string" Define la versión del paquete en la cabecera del POT. El valor por omisión es «VERSION». .SS "Opciones para modificar los archivos PO" .IX Subsection "Opciones para modificar los archivos PO" .IP "\fB\-\-msgmerge\-opt\fR \fIopciones\fR" 4 .IX Item "--msgmerge-opt opciones" Opciones adicionales para \fBmsgmerge\fR(1). .Sp Nota: \fR\f(CB$lang\fR\fB\fR se expandirá al idioma actual. .IP \fB\-\-no\-previous\fR 4 .IX Item "--no-previous" Esta opción retira \fB\-\-previous\fR desde las opciones aprobadas a \fBmsgmerge\fR. Esto es necesarios para admitir versiones de \fBgettext\fR anteriores a 0.16. .IP \fB\-\-previous\fR 4 .IX Item "--previous" Esta opción añade \fB\-\-previous\fR a las opciones introducidas a \fBmsgmerge\fR. Requiere \fBgettext\fR 0.16 o posterior, y está activada por omisión. .SH "ARCHIVO DE CONFIGURACIÓN" .IX Header "ARCHIVO DE CONFIGURACIÓN" po4a espera un archivo de configuraicón como argumento. Este archivo de contener los siguientes elementos: .IP \(bu 4 La ruta a los archivos PO y la lista de idiomas en el proyecto; .IP \(bu 4 Opcionalmente, algunas opciones globales y los denominados alias de configuración que se utilizan como plantillas para configurar archivos maestros individuales; .IP \(bu 4 La lista con cada archivo maestro a traducir, junto con parámetros específicos. .PP Todas las líneas contienen una orden entre paréntesis cuadrados, seguido de sus parámetros. Los comentarios comienzan con el carácter '#' y van hasta el final de la línea. Puede escapar el final de la línea para extender una orden en varias líneas. .PP En esta página se presentan algunos ejemplos completos, mientras que otros ejemplos se pueden encontrar en el directorio \f(CW\*(C`t/cfg\*(C'\fR de la distribución fuente. .SS "Encontrar los archivos PO y POT" .IX Subsection "Encontrar los archivos PO y POT" La solución más simple es proporcionar explicitamente la ruta a los archivos POT y PO, así: .PP .Vb 1 \& [po4a_paths] man/po/project.pot de:man/po/de.po fr:man/po/fr.po .Ve .PP Este especifíca la ruta al archivo POT primero, y después las rutas a los archivos PO en alemán y frncés. .PP La misma información puede escribirse como sigue para reducir el riesgo de errores de copiar/pegar: .PP .Vb 2 \& [po4a_langs] fr de \& [po4a_paths] man/po/project.pot $lang:man/po/$lang.po .Ve .PP El componente \f(CW$lang\fR se expande automaticamente al usar la lista de idiomas proveida, reduciendo así el riesgo de errores de copiar/pegar cuando se añade un nuevo idioma. .PP Puede compactar más la misma información al proporcionalr solamente la ruta al directorio que contiene su proyecto de traducción, como se describe a continuación. .PP .Vb 1 \& [po_directory] man/po/ .Ve .PP El directorio proporcionado debe contener un juego de archivo PO, cada uno con un nombre de la forma \fIXX.po\fR siendo \f(CW\*(C`XX\*(C'\fR el código ISO 639\-1 del idioma usado en ese archivo. El directorio también debe contener un sólo archivo POT, con la extensión \f(CW\*(C`.pot\*(C'\fR. En la primera ejecución, este archivo debe estar vacío pero debe existir (por4a no puee adivinar el nombre por usar antes de la extensión). .PP Note que usted debe elegir sólo uno entre \f(CW\*(C`directorio_po\*(C'\fR y \f(CW\*(C`rutas_po4a\*(C'\fR. El primero (\f(CW\*(C`directorio_po\*(C'\fR) es más compacto, reduciendo más el riesgo de errores de copiar7pegar, pero forzandolo a usar la estructura y nombres de archivos esperados del prooyecto. La segunda (\f(CW\*(C`rutas_po4a\*(C'\fR), es más explicita, probablemente más legible y se recomienda cuando esté montando su primer proyecto con po4a. .PP \fI¿Archivos PO centralizados o divididos?\fR .IX Subsection "¿Archivos PO centralizados o divididos?" .PP De manera predeterminada, po4a produce un sólo archivo PO por idioma objetivo, que contiene el contenido completo de su proyecto de traducción. A medida que su proyecto crezca, el tamaño de estos archivos puede volverse problemático. Al usar weblate, es posible especificar prioridades para cada segmento de traducción (i.e, msgid) de forma que los importante son traducidos primero. Aún así, algunos equipos de traducción prefieren dividir el contenido en varios archivos. .PP Para tener un archivo PO por cada archivo maestro, usted sólo tiene que usar la cadena \f(CW$master\fR en el nombre de sus archivos PO y la línea \f(CW\*(C`[rutas_po4a]\*(C'\fR, como sigue. .PP .Vb 1 \& [po4a_paths] doc/$master/$master.pot $lang:doc/$master/$lang.po .Ve .PP Con esta línea, po4a producirá ficheros separados POT y PO por cada documento para traducir. Por ejemplo, si tiene tres documentos y cinco idiomas, esto resultará en tres ficheros POT y 15 ficheros PO. Estos ficheros son nombrados como especificados sobre la plantilla \f(CW\*(C`po4a_paths\*(C'\fR, con \f(CW$master\fR sustituido como nombre base de cada documento a traducir. En caso de conflicto de nombres, puede especificar el fichero POT para emplear como sigue, con el parámetro \f(CW\*(C`pot=\*(C'\fR. .PP Esta característica además puede ser utilizada para agrupar varios ficheros traducidos dentro del mismo fichero POT. El siguiente ejemplo solo produce 2 ficheros POT: \fIl10n/po/foo.pot\fR (conteniendo el material de \fIfoo/gui.xml\fR) y \fIl10n/po/bar.pot\fR (conteniendo el material tanto de \fIbar/gui.xml\fR como de \fIbar/cli.xml\fR). .PP .Vb 5 \& [po4a_langs] de fr ja \& [po4a_paths] l10n/po/$master.pot $lang:l10n/po/$master.$lang.po \& [type: xml] foo/gui.xml $lang:foo/gui.$lang.xml pot=foo \& [type: xml] bar/gui.xml $lang:bar/gui.$lang.xml pot=bar \& [type: xml] bar/cli.xml $lang:bar/cli.$lang.xml pot=bar .Ve .PP En modo despliegue, \fBpo4a\fR compila un compendio temporal durante la actualización de PO, para compartir las traducciones entre todos los ficheros PO. Si dos PO tienen diferentes traducciones de la misma cadena, \fBpo4a\fR marcará esta cadena como difusa («fuzzy») y mandará ambas traducciones a todos los ficheros PO que contengan está cadena. Cuando no quede difuso por el traductor, la traducción es utilizada automáticamente en cada fichero PO. .SS "Especificar los documentos a traducir" .IX Subsection "Especificar los documentos a traducir" También debe enumerar los documentos que deben traducirse. Para cada archivo maestro, debe especificar el analizador de formato que debe utilizarse, la ubicación del documento traducido que debe producirse y, opcionalmente, alguna configuración. Los nombres de archivo deben entrecomillarse o escaparse si contienen espacios. He aquí un ejemplo: .PP .Vb 4 \& [type: sgml] "doc/my stuff.sgml" "fr:doc/fr/mon truc.sgml" de:doc/de/mein\e kram.sgml \& [type: man] script fr:doc/fr/script.1 de:doc/de/script.1 \& [type: docbook] doc/script.xml fr:doc/fr/script.xml \e \& de:doc/de/script.xml .Ve .PP Pero de nuevo, estas líneas complejas son difíciles para leer y modificar, p. ej. cuando agregue un idioma nuevo. Es mucho más fácil reorganizar cosas empleando la plantilla \f(CW$lang\fR como sigue: .PP .Vb 3 \& [type: sgml] doc/mi_material.sgml $lang:doc/$lang/mi_material.sgml \& [type: man] script.1 $lang:po/$lang/script.1 \& [type: docbook] doc/script.xml $lang:doc/$lang/script.xml .Ve .SS "Especificar opciones" .IX Subsection "Especificar opciones" Hay dos tipos de opciones: \fIopciones po4a\fR son valores predeterminados para las opciones de línea de orden po4a mientras que \fIopciones de formato\fR son utilizadas para cambiar el comportamiento de los intérpretes del formato. Como una \fIopciones de po4a\fR, pudo por ejemplo especificar en su fichero de configuración que el valor predeterminado del parámetro de línea de orden \fB\-\-keep\fR es un 50% en vez de un 80%. Las \fIopciones de formato\fR están documentadas en una página específica de cada módulo de intérprete, p.ej. \fBLocale::Po4a::Xml\fR\|(3pm). Pudo por ejemplo aprobar \fBnostrip\fR al intérprete XML para no recortar los espacios alrededor de las cadenas extraídas. .PP Puede pasar estas opciones para un fichero maestro específico, o incluso para una traducción específica de ese fichero, utilizando \f(CW\*(C`opt:\*(C'\fR y \f(CW\*(C`opt_XX:\*(C'\fR para el idioma \f(CW\*(C`XX\*(C'\fR. En el ejemplo siguiente, la opción \fBnostrip\fR es pasada al intérprete XML (para todos los idiomas), mientras que el umbral será reducido a 0% para la traducción francesa (que es por lo tanto siempre conservada). .PP .Vb 1 \& [type:xml] toto.xml $lang:toto.$lang.xml opt:"\-o nostrip" opt_es:"\-\-keep 0" .Ve .PP En cualquier caso, estos segmentos de configuración deben estar ubicados al final de la línea. La declaración de ficheros deben primero venir, después el adjunto si hay alguno (vea debajo), y después solamente las opciones. El agrupamiento de configuración de segmentos no es muy importante, debido a que los elementos están concatenados internamente como cadenas. Los siguientes ejemplos son todos equivalentes: .PP .Vb 3 \& [type:xml] toto.xml $lang:toto.$lang.xml opt:"\-\-keep 20" opt:"\-o nostrip" opt_es:"\-\-keep 0" \& [type:xml] toto.xml $lang:toto.$lang.xml opt:"\-\-keep 20 \-o nostrip" opt_es:"\-\-keep 0" \& [type:xml] toto.xml $lang:toto.$lang.xml opt:\-\-keep opt:20 opt:\-o opt:nostrip opt_es:\-\-keep opt_es:0 .Ve .PP Anote que las opciones específicas del idioma no son utilizadas cuando crea el fichero POT. Es por ejemplo imposible aprobar \fBnostrip\fR al intérprete solamente cuando construya la traducción francesa, porque el mismo fichero POT es utilizado para actualizar cada idioma. Por tanto las opciones solamente que pueda ser específicas del idioma son las que son utilizadas cuando produce la traducción, como la opción \f(CW\*(C`\-\-keep\*(C'\fR. .PP \fIConfiguración de aliases\fR .IX Subsection "Configuración de aliases" .PP Para aprobar las mismas opciones a varios ficheros, lo mejor es definir un tipo alias como sigue. En el ejemplo siguiente, \f(CW\*(C`\-\-keep 0\*(C'\fR es pasado a cada traducción italiana utilizando este tipo \f(CW\*(C`test\*(C'\fR, que es una extensión del tipo \f(CW\*(C`man\*(C'\fR. .PP .Vb 2 \& [po4a_alias:test] man opt_it:"\-\-keep 0" \& [type: test] man/page.1 $lang:man/$lang/page.1 .Ve .PP También puede extender un tipo existente reutilizando el mismo nombre para el alias tal como sigue. Esto no es interpretado como una definición recursiva errónea. .PP .Vb 2 \& [po4a_alias:man] man opt_it:"\-\-keep 0" \& [type: man] man/page.1 $lang:man/$lang/page.1 .Ve .PP \fIOpciones predeterminadas globales\fR .IX Subsection "Opciones predeterminadas globales" .PP Además puede utilizar líneas de \f(CW\*(C`[opciones]\*(C'\fR para definir opciones que deben ser empleadas para todos los ficheros, independientemente de su tipo. .PP .Vb 1 \& [opciones] \-\-keep 20 \-\-option sin\-tira .Ve .PP Como con las opciones de línea de orden, puede abreviar los parámetros pasados dentro del fichero de configuración: .PP .Vb 1 \& [opciones] \-k 20 \-o nostrip .Ve .PP \fIOpciones prioritarias\fR .IX Subsection "Opciones prioritarias" .PP Las opciones de cada fuente están concatenadas, asegurando que los valores predeterminados puedan ser fácilmente anulados por opciones más específicas. El pedido es como sigue: .IP \(bu 4 Las \f(CW\*(C`[opciones]\*(C'\fR de líneas proporciona valores predeterminados que pueden ser anuladas por cualquier otro origen. .IP \(bu 4 Tipo de aliases estarán cuando necesite. Parámetros específicos del idioma anula los aplicables a todos los idiomas. .IP \(bu 4 Los parámetros que son específicos a un fichero maestro dado anula ambos predeterminados y los que vengan desde el tipo alias. En este caso también, los parámetros específicos del idioma anulan los globales. .IP \(bu 4 Finalmente, los parámetros proporcionado en la línea de orden \fBpo4a\fR supera cualquiera de los parámetros desde el fichero de configuración. .PP \fIEjemplo\fR .IX Subsection "Ejemplo" .PP Aquí hay un ejemplo mostrando como entrecomillas los espacios y entrecomillados: .PP .Vb 1 \& [po_directory] man/po/ \& \& [opciones] \-\-master\-charset UTF\-8 \& \& [po4a_alias:man] man opt:"\-o \e"mdoc=NOMBRE,VEA ADEMÁS\e"" \& [type:man] t\-05\-config/test02_man.1 $lang:tmp/test02_man.$lang.1 \e \& opt:"\-k 75" opt_es:"\-L UTF\-8" opt_es:\-\-verbose .Ve .SS "Apéndice: Añadiendo contenido adicional en la traducción" .IX Subsection "Apéndice: Añadiendo contenido adicional en la traducción" Si desea agregar una sección adicional a la traducción, por ejemplo para proporcionar reconocimiento a los traductores, entonces necesita definir un addendum a la línea definiendo su fichero maestro. Refiérase a la página \fBpo4a\fR\|(7) para más detalles en la sintaxis de ficheros addendum. .PP .Vb 2 \& [type: pod] script es:doc/es/script.1 \e \& add_es:doc/l10n/script.es.add .Ve .PP Además puede emplear plantillas del idioma como sigue: .PP .Vb 2 \& [type: pod] script $lang:doc/$lang/script.1 \e \& add_$lang:doc/l10n/script.$lang.add .Ve .PP Si falla un addendum al aplicar, la traducción es descartada. .PP \fIModificadores para declaración de addendum\fR .IX Subsection "Modificadores para declaración de addendum" .PP Modificadores de adjuntos pueden simplificar la configuración del fichero dentro del caso donde ninguno de los idioma proporciona un adjunto o cuando el listado de los adjuntos cambia desde un idioma al otro. El modificador es un carácter único localizado antes del nombre del fichero. .IP \fB?\fR 2 .IX Item "?" Incluye \fIruta_al_apéndice\fR si el fichero sí existe, y no hace nada de lo contrario. .IP \fB@\fR 2 .IX Item "@" \&\fIruta_al_apéndice\fR no es un apéndice normal, sino un fichero que contiene una lista de apéndices, uno por línea. Cada apéndice puede ir precedido de argumentos. .IP \fB!\fR 2 .IX Item "!" Si \fIruta_al_apéndice\fR se descarta, no se cargará, independientemente de cualquier especificación adicional referida al apéndice. .PP Lo siguiente incluye un adjunto dentro de cualquier idioma, pero si solamente existe. No se comunica un error si el adjunto no existe. .PP .Vb 1 \& [type: pod] script $lang:doc/$lang/script.1 add_$lang:?doc/l10n/script.$lang.add .Ve .PP Lo siguiente incluye un listado de adjuntos por cada idioma: .PP .Vb 1 \& [type: pod] script $lang:doc/$lang/script.1 add_$lang:@doc/l10n/script.$lang.add .Ve .SS "Filtrar las cadenas traducidas" .IX Subsection "Filtrar las cadenas traducidas" A veces, desea ocultar algunos segmentos desde el proceso de traducción. Para eso extender, puede proporcionar un parámetro \f(CW\*(C`pot_in\*(C'\fR a su fichero maestro para especificar el nombre del fichero a utilizar en lugar del maestro real cuando compile el fichero POT. Aquí hay un ejemplo: .PP .Vb 3 \& [type:docbook] libro.xml \e \& pot_in:book\-filtered.xml \e \& $lang:book.$lang.xml .Ve .PP Con este parámetro, los segmentos a traducir serán extraídos desde el \fIlibro.filtrado.xml\fR (ese debe ser generado antes de invocar \fBpo4a\fR) mientras los ficheros traducidos serán compilados desde \fIlibro.xml\fR. Como un resultado, cualquier segmento que es parte de \fIlibro.xml\fR pero no está dentro del \fIlibro\-filtrado.xml\fR no será incluido dentro de los ficheros PO, impidiendo a los traductores desde proporionar una traducción para ellos. Por tanto estos segmentos serán dejados sin modificar cuando produzca los documentos traducidos. Esto naturalmente decrementa el nivel de traducción, por lo que quizá necesita la opción \f(CW\*(C`\-\-keep\*(C'\fR para asegurar que el documento es generado a pesar de todo. .SH "VÉASE TAMBIÉN" .IX Header "VÉASE TAMBIÉN" \&\fBpo4a\-gettextize\fR\|(1), \fBpo4a\fR\|(7). .SH AUTORES .IX Header "AUTORES" .Vb 3 \& Denis Barbier \& Nicolas François \& Martin Quinson (mquinson#debian.org) .Ve .SH TRADUCCION .IX Header "TRADUCCION" .Vb 2 \& Jordi Vilalta \& Omar Campagne .Ve .SH "DERECHO DE COPIA Y LICENCIA" .IX Header "DERECHO DE COPIA Y LICENCIA" Copyright 2002\-2023 por SPI, inc. .PP Este programa es software libre; puede redistribuirlo y/o modificarlo bajo los términos de la GPL v2.0 o posterior (consulte el archivo COPYING).