Otros formatos de salida de conversión TeX | .NETO

Es muy poco probable que actualmente quieras convertir un archivo TeX escrito en cualquier otro formato que no sea LaTeX. Pero esto es posible si estás estudiando el lenguaje TeX y/o sus aspectos internos por algún motivo. De todos modos, Aspose.TeX para .NET le permite convertir archivos escritos en formato Plain TeX. También le permite crear formatos personalizados y componer documentos diseñados en estos formatos.

Comenzaremos creando un formato personalizado.

Creando un formato personalizado

Recordemos que el archivo de formato es un volcado binario del estado interno del motor TeX.

 1// Create TeX engine options for no format upon ObjectTeX engine extension.
 2TeXOptions options = TeXOptions.ConsoleAppOptions(TeXConfig.ObjectIniTeX);
 3// Specify a file system working directory for the input.
 4options.InputWorkingDirectory = new InputFileSystemDirectory(RunExamples.InputDirectory);
 5// Specify a file system working directory for the output.
 6options.OutputWorkingDirectory = new OutputFileSystemDirectory(RunExamples.OutputDirectory);
 7
 8// Run format creation.
 9TeXJob.CreateFormat("customtex", options);
10
11// For further output to look fine.
12options.TerminalOut.Writer.WriteLine();

Como puede ver, el código es similar al código para convertir un archivo TeX. Pero hay algunas diferencias.

Primero, aquí usamos la configuración del trabajo TeXConfig.ObjectIniTeX. Se trata de una configuración especial que deja el estado del motor “virgen”, es decir, los parámetros internos tienen sus valores por defecto y el conjunto de secuencias de control coincide con el conjunto de primitivas. En nuestro ejemplo, el conjunto de primitivas se amplía en el sentido mencionado aquí.

A continuación, configuramos los directorios de trabajo de entrada y salida como de costumbre. El directorio de trabajo de entrada debe contener el archivo fuente del formato principal y todas sus dependencias.

Y la segunda diferencia clave es la forma en que ejecutamos el trabajo. En esta ocasión utilizamos el método estático CreateFormat(), que junto con las opciones toma el nombre del archivo fuente principal, que debe ser el mismo que el nombre del formato.

Componer un archivo TeX en su formato personalizado

Ahora que tenemos nuestro propio formato TeX, queremos componer un archivo TeX escrito en este formato. Aquí está el código:

 1// Create the file system input working directory.
 2// Create the format provider using the file system input working directory.
 3// We use the project output directory as our custom format file is supposed to be located there.
 4using (FormatProvider formatProvider =
 5    new FormatProvider(new InputFileSystemDirectory(RunExamples.OutputDirectory), "customtex"))
 6{
 7    // Create conversion options for a custom format upon ObjectTeX engine extension.
 8    TeXOptions options = TeXOptions.ConsoleAppOptions(TeXConfig.ObjectTeX(formatProvider));
 9    options.JobName = "typeset-with-custom-format";
10    // Specify the input working directory. This is not required here as we are providing the main input as a stream.
11    // But it is required when the main input has dependencies (e.g. images).
12    options.InputWorkingDirectory = new InputFileSystemDirectory(RunExamples.InputDirectory);
13    // Specify a file system working directory for the output.
14    options.OutputWorkingDirectory = new OutputFileSystemDirectory(RunExamples.OutputDirectory);
15
16    // Run the job.
17    new TeXJob(new MemoryStream(Encoding.ASCII.GetBytes(
18            "Congratulations! You have successfully typeset this text with your own TeX format!\\end")),
19            new XpsDevice(), options).Run();
20
21    // For further output to look fine.
22    options.TerminalOut.Writer.WriteLine();
23}

Obviamente, tenemos que especificar el formato de alguna manera. En primer lugar, necesitamos crear una instancia de la clase FormatProvider. Luego, en el constructor de opciones, usamos la configuración TeXConfig.ObjectTeX(), que toma nuestro proveedor de formato como argumento y carga el formato encima del estado “virgen” del motor.

El resto del código debería resultarle familiar. Utiliza las características analizadas anteriormente en esta guía.

Composición tipográfica de un archivo TeX en formato Plain TeX

Si descartamos el proveedor de formato del código que acabamos de demostrar, el motor cargará el formato predeterminado, que es Object TeX en su cuarto sentido. Por lo tanto, si tiene un archivo TeX escrito en formato Plain TeX, de esta manera puede convertirlo a cualquier formato de destino compatible.

Subscribe to Aspose Product Updates

Get monthly newsletters & offers directly delivered to your mailbox.