File: genencoded

package info (click to toggle)
latexml 0.8.8-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 31,920 kB
  • sloc: xml: 109,048; perl: 30,224; sh: 179; javascript: 28; makefile: 13
file content (102 lines) | stat: -rwxr-xr-x 3,666 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
#!/usr/bin/env perl
# /=====================================================================\ #
# |  genencoded                                                         | #
# | generate an input encoding test case                                | #
# |=====================================================================| #
# | support tools for LaTeXML:                                          | #
# |  Public domain software, produced as part of work done by the       | #
# |  United States Government & not subject to copyright in the US.     | #
# |---------------------------------------------------------------------| #
# | Bruce Miller <bruce.miller@nist.gov>                        #_#     | #
# | http://dlmf.nist.gov/LaTeXML/                              (o o)    | #
# \=========================================================ooo==U==ooo=/ #

use strict;
use warnings;
use FindBin;
use Pod::Usage;

pod2usage(1) unless @ARGV;

our $TESTDEST = "$FindBin::RealBin/../t/encoding";

for my $encoding (@ARGV) {
  #----------------------------------------
  # Find & Scan the TeX encoding file
  my $defpath = `kpsewhich $encoding.def`;
  chomp($defpath);
  die "Could not find encoding file for '$encoding'" unless $defpath;
  my @defn = ();
  my $ENC;
  open($ENC, '<', $defpath) or die "Could not open encoding file '$defpath': $!";
  while (<$ENC>) {
    chomp;
    s/\s*%.*//;
    if (/\s*\\DeclareInputText\{(\d+)\}\{(?:.*)\}$/) { $defn[$1] = pack('C', $1); }
    elsif (/\s*\\DeclareInputMath\{(\d+)\}\{(?:.*)\}$/) { $defn[$1] = '$' . pack('C', $1) . '$'; }
    elsif (/Declare/) { print STDERR "Misunderstood line \"$_\"\n"; } }
  close($ENC);

  #----------------------------------------
  # Generate the TeX sample.
  # Note that we are writing a Non-ASCII TeX file!
  my $dest = "$TESTDEST/$encoding.tex";
  my $fontenc = ($encoding =~ /cyrill/ ? 'T2A' : 'T1');
  my $TEX;
  open($TEX, '>', $dest) or die "Couldn't open '$dest' for writing; $!";
  binmode($TEX);
  print $TEX "\\documentclass{article}\n";
  print $TEX "\\usepackage[$fontenc]{fontenc}\n";
  print $TEX "\\usepackage{textcomp}\n";
  print $TEX "\\usepackage[$encoding]{inputenc}\n";
  print $TEX "\\begin{document}\n";
  print $TEX "\\section{Input encoding $encoding}\n";
  print $TEX "\\begin{tabular}{l|cccccccccccccccc}\n";

  for (my $c = 0 ; $c < 16 ; $c++) {    # Print heading
    print $TEX " & " . uc(sprintf("%x", $c)); }
  print $TEX "\\\\ \\hline\n";
  for (my $r = 0 ; $r < 16 ; $r++) {
    my $empty = 1;
    for (my $c = 0 ; $c < 16 ; $c++) {
      my $p = $r * 16 + $c;
      my $e = $defn[$p];
      $empty = 0 if defined $e; }
    if (!$empty) {
      print $TEX uc(sprintf("%x", $r)) . "x";
      for (my $c = 0 ; $c < 16 ; $c++) {
        my $p = $r * 16 + $c;
        my $e = $defn[$p];
        print $TEX " & ";
        print $TEX $e if defined $e; }
      print $TEX "\\\\\n"; } }
  print $TEX "\\end{tabular}\n";
  print $TEX "\\end{document}\n";
  close($TEX);

  print "Wrote $dest for encoding $encoding\n";
}

#%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

__END__

=head1 NAME

genencoding - generate encoding test samples

=head1 SYNOPSIS

C<genencoded> I<encoding> ...

Generate test (or sample) documents that demonstrate and test
the given encodings, in the LaTeXML t/encoding directory.

Since the coverage, completeness or even correctness of the
encoding definitions changes from one TeX release to another,
you may occasionally find it necessary to manually delete some cells
from the generated table to make the test case more portable.

=cut

#%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%