Advanced Installer (AIL)
Traducción con IA para archivos de localización de Advanced Installer con Lingo.dev CLI
¿Qué es Advanced Installer AIL?
Advanced Installer es una herramienta de creación de instaladores de Windows que ayuda a los desarrolladores a crear paquetes MSI (Microsoft Installer). AIL (Advanced Installer Localization) es un formato de diccionario multiidioma basado en XML que se utiliza para localizar diálogos, botones, mensajes y propiedades del instalador. Todas las traducciones para múltiples idiomas se almacenan en un único archivo AIL.
¿Qué es Lingo.dev CLI?
Lingo.dev CLI es una CLI gratuita y de código abierto para traducir aplicaciones y contenido con IA. Está diseñada para reemplazar el software tradicional de gestión de traducciones mientras se integra con los pipelines existentes.
Para obtener más información, consulta Descripción general.
Acerca de esta guía
Esta guía explica cómo traducir archivos AIL de Advanced Installer con Lingo.dev CLI.
Aprenderás a:
- Crear un proyecto desde cero
- Configurar un pipeline de traducción
- Generar traducciones con IA
Requisitos previos
Para usar Lingo.dev CLI, asegúrate de tener instalado Node.js v18+:
❯ node -v
v22.17.0
Paso 1. Configurar un proyecto
En el directorio de tu proyecto, crea un archivo i18n.json:
{
"$schema": "https://lingo.dev/schema/i18n.json",
"version": "1.10",
"locale": {
"source": "en",
"targets": ["es"]
},
"buckets": {}
}
Este archivo define el comportamiento del pipeline de traducción, incluyendo qué idiomas traducir y dónde existe el contenido localizable en el sistema de archivos.
Para obtener más información sobre las propiedades disponibles, consulta i18n.json.
Paso 2. Configurar el idioma de origen
El idioma de origen es el idioma y la región originales en los que se escribió tu contenido. Para configurar el idioma de origen, establece la propiedad locale.source en el archivo i18n.json:
{
"$schema": "https://lingo.dev/schema/i18n.json",
"version": "1.10",
"locale": {
"source": "en",
"targets": ["es"]
},
"buckets": {}
}
El idioma de origen debe proporcionarse como una etiqueta de idioma BCP 47.
Para ver la lista completa de códigos de idioma que admite Lingo.dev CLI, consulta Códigos de idioma admitidos.
Paso 3. Configurar los idiomas de destino
Los idiomas de destino son los idiomas y regiones a los que deseas traducir tu contenido. Para configurar los idiomas de destino, establece la propiedad locale.targets en el archivo i18n.json:
{
"$schema": "https://lingo.dev/schema/i18n.json",
"version": "1.10",
"locale": {
"source": "en",
"targets": ["es"]
},
"buckets": {}
}
Paso 4. Crear el contenido de origen
Si aún no lo has hecho, crea un archivo AIL que contenga el contenido a traducir. Los archivos AIL utilizan una estructura XML donde todas las traducciones de idiomas se almacenan en un único archivo.
Estructura del archivo:
<?xml version="1.0" encoding="UTF-8"?>
<DICTIONARY type="multilanguage">
<ENTRY id="Control.Text.WelcomeDlg#Title">
<STRING lang="en" value="Welcome to the Setup Wizard"/>
</ENTRY>
<ENTRY id="Control.Button.Next">
<STRING lang="en" value="Next"/>
</ENTRY>
</DICTIONARY>
Contenido traducible:
- Cada elemento
ENTRYrepresenta una cadena traducible con un atributoidúnico - Los elementos
STRINGdentro de cadaENTRYcontienen traducciones para idiomas específicos - El atributo
langespecifica el código de idioma - El atributo
valuecontiene el texto traducible
Convenciones de ID de entrada:
Los archivos AIL utilizan ID estructurados para organizar el contenido del instalador:
- Texto de control:
Control.Text.DialogName#ElementName - Botones de control:
Control.Button.ButtonName - Propiedades:
Property.PropertyName
Por ejemplo:
Control.Text.WelcomeDlg#Title- Texto del título para el diálogo de bienvenidaControl.Button.Next- Texto para el botón SiguienteProperty.ProductName- Propiedad del nombre del producto
Variables de Advanced Installer:
Los archivos AIL admiten variables de Advanced Installer que se reemplazan en tiempo de ejecución:
[ProductName]- Se reemplaza con el nombre del producto[ProductVersion]- Se reemplaza con la versión del producto[Manufacturer]- Se reemplaza con el nombre del fabricante
Estas variables se conservan durante la traducción:
<ENTRY id="Control.Text.WelcomeDlg#Title">
<STRING lang="en" value="Welcome to [ProductName] Setup"/>
</ENTRY>
Modo de salida:
El bucket AIL modifica el archivo original en lugar de crear archivos separados para cada idioma. Cuando ejecutas traducciones, la CLI añade o actualiza elementos STRING para los idiomas de destino dentro del archivo AIL existente. Esto se debe a que los archivos AIL están diseñados para almacenar todas las traducciones de idiomas en un único archivo.
Paso 5. Crear un bucket
-
En el archivo
i18n.json, añade un objeto"ail"al objetobuckets:{ "$schema": "https://lingo.dev/schema/i18n.json", "version": "1.10", "locale": { "source": "en", "targets": ["es"] }, "buckets": { "ail": {} } } -
En el objeto
"ail", define un array de uno o más patronesinclude:{ "$schema": "https://lingo.dev/schema/i18n.json", "version": "1.10", "locale": { "source": "en", "targets": ["es"] }, "buckets": { "ail": { "include": ["./*.ail"] } } }Estos patrones definen qué archivos traducir.
Los patrones en sí:
- pueden apuntar a rutas de archivos (p. ej.,
"./installer.ail") - pueden usar asteriscos como comodines (p. ej.,
"./*.ail") - no usan el marcador de posición
[locale](ya que todos los locales están en el mismo archivo)
Los patrones glob recursivos (p. ej.,
**/*.ail) no son compatibles. - pueden apuntar a rutas de archivos (p. ej.,
Paso 6. Configurar un LLM
Lingo.dev CLI utiliza modelos de lenguaje de gran tamaño (LLM) para traducir contenido con IA. Para usar uno de estos modelos, necesitas una clave API de un proveedor compatible.
Para empezar lo más rápido posible, recomendamos usar Lingo.dev Engine:
-
Ejecuta el siguiente comando:
npx lingo.dev@latest loginEsto abrirá tu navegador predeterminado y te pedirá que te autentiques.
-
Sigue las instrucciones.
Paso 7. Generar las traducciones
En el directorio que contiene el archivo i18n.json, ejecuta el siguiente comando:
npx lingo.dev@latest run
Este comando:
- Lee el archivo
i18n.json. - Encuentra los archivos que necesitan ser traducidos.
- Extrae el contenido traducible de los archivos.
- Utiliza el LLM configurado para traducir el contenido extraído.
- Escribe el contenido traducido de vuelta al sistema de archivos.
La primera vez que se generan las traducciones, se crea un archivo i18n.lock. Este archivo realiza un seguimiento del contenido que ha sido traducido, evitando retraducciones innecesarias en ejecuciones posteriores.
Ejemplo
Antes de la traducción (example.ail)
<?xml version="1.0" encoding="UTF-8"?>
<DICTIONARY type="multilanguage">
<ENTRY id="Control.Text.WelcomeDlg#Title">
<STRING lang="en" value="Welcome to the [ProductName] Setup Wizard"/>
</ENTRY>
<ENTRY id="Control.Text.WelcomeDlg#Description">
<STRING lang="en" value="The Setup Wizard will install [ProductName] on your computer. Click Next to continue or Cancel to exit the Setup Wizard."/>
</ENTRY>
<ENTRY id="Control.Text.LicenseAgreementDlg#Title">
<STRING lang="en" value="End-User License Agreement"/>
</ENTRY>
<ENTRY id="Control.Text.LicenseAgreementDlg#AcceptCheckbox">
<STRING lang="en" value="I accept the terms in the License Agreement"/>
</ENTRY>
<ENTRY id="Control.Button.Next">
<STRING lang="en" value="Next"/>
</ENTRY>
<ENTRY id="Control.Button.Cancel">
<STRING lang="en" value="Cancel"/>
</ENTRY>
<ENTRY id="Property.ProductName">
<STRING lang="en" value="My Application"/>
</ENTRY>
</DICTIONARY>
Después de la traducción (example.ail)
<?xml version="1.0" encoding="UTF-8"?>
<DICTIONARY type="multilanguage">
<ENTRY id="Control.Text.WelcomeDlg#Title">
<STRING lang="en" value="Welcome to the [ProductName] Setup Wizard"/>
<STRING lang="es" value="Bienvenido al asistente de instalación de [ProductName]"/>
</ENTRY>
<ENTRY id="Control.Text.WelcomeDlg#Description">
<STRING lang="en" value="The Setup Wizard will install [ProductName] on your computer. Click Next to continue or Cancel to exit the Setup Wizard."/>
<STRING lang="es" value="El asistente de instalación instalará [ProductName] en su ordenador. Haga clic en Siguiente para continuar o en Cancelar para salir del asistente de instalación."/>
</ENTRY>
<ENTRY id="Control.Text.LicenseAgreementDlg#Title">
<STRING lang="en" value="End-User License Agreement"/>
<STRING lang="es" value="Acuerdo de licencia para el usuario final"/>
</ENTRY>
<ENTRY id="Control.Text.LicenseAgreementDlg#AcceptCheckbox">
<STRING lang="en" value="I accept the terms in the License Agreement"/>
<STRING lang="es" value="Acepto los términos del acuerdo de licencia"/>
</ENTRY>
<ENTRY id="Control.Button.Next">
<STRING lang="en" value="Next"/>
<STRING lang="es" value="Siguiente"/>
</ENTRY>
<ENTRY id="Control.Button.Cancel">
<STRING lang="en" value="Cancel"/>
<STRING lang="es" value="Cancelar"/>
</ENTRY>
<ENTRY id="Property.ProductName">
<STRING lang="en" value="My Application"/>
<STRING lang="es" value="My Application"/>
</ENTRY>
</DICTIONARY>
i18n.json
{
"$schema": "https://lingo.dev/schema/i18n.json",
"version": "1.10",
"locale": {
"source": "en",
"targets": ["es"]
},
"buckets": {
"ail": {
"include": ["./*.ail"]
}
}
}
i18n.lock
version: 1
checksums:
f84d41a1c3ad7e70e25c84811ef9baef:
Control.Text.WelcomeDlg%23Title: 93af4b47a8c0a84ce9fb82d2ee2bca13
Control.Text.WelcomeDlg%23Description: 9cbc6500217ae2a7b3ffd74a3c723493
Control.Text.LicenseAgreementDlg%23Title: 3fe6d3757d7129ede78b41dd06042bf2
Control.Text.LicenseAgreementDlg%23AcceptCheckbox: 768d9d11db014facbc1b65af8e39e260
Control.Button.Next: 4c49d903308e8e3f5c866cfd78ef0e89
Control.Button.Cancel: a149e8d5b349f68b3cfc9fbe6b23cbb4
Property.ProductName: c215a8d46c95f00089c5ea0d17eef742