summaryrefslogtreecommitdiff
path: root/doc/afmmetrics.pl
blob: b93d22e93795d411a9c6407e1673227ff9030579 (plain)
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
#!/usr/bin/perl
#
# Parse AFM metric files
#

@widths = ((undef)x256);

while ( $line = <STDIN> ) {
    if ( $line =~ /^\s*FontName\s+(.*)\s*$/ ) {
	$fontname = $1;
    } elsif ( $line =~ /^\s*StartCharMetrics\b/ ) {
	$charmetrics = 1;
    } elsif ( $line =~ /^\s*EndCharMetrics\b/ ) {
	$charmetrics = 0;
    } elsif ( $line =~ /^\s*StartKernPairs\b/ ) {
	$kerndata = 1;
    } elsif ( $line =~ /^\s*EndKernPairs\b/ ) {
	$kerndata = 0;
    } elsif ( $charmetrics ) {
	@data = split(/\s*;\s*/, $line);
	undef $charcode, $width, $name;
	foreach $d ( @data ) {
	    @dd = split(/\s+/, $d);
	    if ( $dd[0] eq 'C' ) {
		$charcode = $dd[1];
	    } elsif ( $dd[0] eq 'WX' ) {
		$width = $dd[1];
	    } elsif ( $dd[0] eq 'W' ) {
		$width = $dd[2];
	    } elsif ( $dd[0] eq 'N' ) {
		$name = $dd[1];
	    }
	}
	if ( defined($name) && defined($width) ) {
	    $charwidth{$name} = $width;
	}
    } elsif ( $kerndata ) {
	@data = split(/\s+/, $line);
	if ( $data[0] eq 'KPX' ) {
	    if ( defined($charcodes{$data[1]}) &&
		 defined($charcodes{$data[2]}) &&
		 $data[3] != 0 ) {
		$kernpairs{chr($charcodes{$data[1]}).
			   chr($charcodes{$data[2]})} = $data[3];
	    }
	}
    }
}

sub qstr($) {
    my($s) = @_;
    my($o,$c,$i);
    $o = '"';
    for ( $i = 0 ; $i < length($s) ; $i++ ) {
	$c = substr($s,$i,1);
	if ( $c lt ' ' || $c gt '~' ) {
	    $o .= sprintf("\\%03o", ord($c));
	} elsif ( $c eq "\'" || $c eq "\"" || $c eq "\\" ) {
	    $o .= "\\".$c;
	} else {
	    $o .= $c;
	}
    }
    return $o.'"';
}

$psfont = $fontname;
$psfont =~ s/[^A-Za-z0-9]/_/g;

print "%PS_${psfont} = (\n";
print "  name => \'$fontname\',\n";
print "  widths => {";
$lw = 100000;
foreach $cc ( keys(%charwidth) ) {
    $ss = sprintf('%s => %d, ', qstr($cc), $charwidth{$cc});
    $lw += length($ss);
    if ( $lw > 72 ) {
	print "\n    ";
	$lw = 4 + length($ss);
    }
    print $ss;
}
print "\n  }\n";
#print "  kern => {";
#$lw = 100000;
#foreach $kp ( keys(%kernpairs) ) {
#    $ss = sprintf('%s => %d, ', qstr($kp), $kernpairs{$kp});
#    $lw += length($ss);
#    if ( $lw > 72 ) {
#	print "\n    ";
#	$lw = 4 + length($ss);
#    }
#    print $ss;
#}
#print "  }\n";
print ");\n";
print "1;\n";