123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539 |
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- /onechar 1 string def
- /edef {exch def} def
- /WinAnsiEncoding dup /Encoding findresource def
-
-
-
- /print-charname {
- PFMCharSet 0 eq {
- WinAnsiEncoding
- } {
- PFBencoding
- } ifelse
- exch get =string cvs dup
- (.notdef) eq {
- /was.notdef true def
- } if
- print.to.ofi ( ) print.to.ofi
- } def
-
- /printquit {print flush quit} def
-
-
- /eolch (\r\n) def
- /=only.to.ofi {ofi exch write=only} def
- /print.to.ofi {ofi exch writestring} def
- /=to.ofi { =only.to.ofi eolch print.to.ofi } def
-
-
- /readb-p {currPFMfile read not {(Unexpected EOF\n) printquit} if} def
- /readw-p {readb-p readb-p 256 mul add} def
- /reads-p {readw-p dup 32768 ge {65536 sub} if} def
- /readd-p {readb-p readb-p readb-p readb-p 256 mul add 256 mul add 256 mul add} def
- /readl-p /readd-p load def
- /skipb-p {readb-p pop} def
- /skipw-p {skipb-p skipb-p} def
- /skips-p /skipw-p load def
- /skipd-p {skipb-p skipb-p skipb-p skipb-p} def
- /skipl-p /skipd-p load def
- /skipa-p { {skipb-p} repeat} def
-
-
-
-
- /readPFMheader {
- currPFMfile bytesavailable
-
-
-
- skipw-p
- readd-p
- ne {(Wrong file size\n) printquit} if
- 60 skipa-p
- skipw-p
- skipw-p
- skipw-p
- skipw-p
- skipw-p
- skipw-p
- skipw-p
- skipb-p
- skipb-p
- skipb-p
- skipw-p
- readb-p
- /PFMCharSet edef
- skipw-p
- skipw-p
- skipb-p
- skipw-p
- skipw-p
- skipb-p
- skipb-p
- skipb-p
- skipb-p
- skipw-p
- skipd-p
- skipd-p
- skipd-p
- skipd-p
-
-
-
-
-
- skipw-p
- readd-p
- /PFMExtMetricOffset edef
- skipd-p
- skipd-p
- readd-p
- /PFMPairKernTableOffset edef
- skipd-p
- skipd-p
- skipd-p
- } def
-
-
-
-
-
- /readPFMExtMetric {
- currPFMfile PFMExtMetricOffset setfileposition
- skips-p
- skips-p
- skips-p
- skips-p
- skips-p
- skips-p
- skips-p
- reads-p
- /PFMCapHeight edef
- reads-p
- /PFMXHeight edef
- reads-p
- /PFMLowerCaseAscent edef
- reads-p
- neg /PFMLowerCaseDescent edef
- skips-p
- skips-p
- skips-p
- skips-p
- skips-p
- skips-p
- skips-p
- skips-p
- skips-p
- skips-p
- skips-p
- skips-p
- skips-p
- readw-p
- /PFMNumberofKernPairs edef
- skipw-p
- } def
-
-
-
-
-
- /readPFMKernPairs {
- currPFMfile () ne {
- PFMdict begin
- PFMPairKernTableOffset 0 ne {
- currPFMfile PFMPairKernTableOffset setfileposition
- readw-p
-
-
- PFMNumberofKernPairs
-
- ne {
- (Inconsistent number of kern pairs\n) printquit
- } if
- (StartKernData) =to.ofi
- (StartKernPairs ) print.to.ofi
- PFMNumberofKernPairs =to.ofi
-
-
-
- /was.notdef false def
- PFMNumberofKernPairs {
- (KPX ) print.to.ofi
- readb-p
- print-charname
- readb-p
- print-charname
- reads-p
- =to.ofi
- } repeat
- was.notdef {
- (.notdef character ocurred among kern pairs) =
- (you'd better check the resulting AFM file.) =
- } if
- (EndKernPairs) =to.ofi
- (EndKernData) =to.ofi
- } if
- end
- } if
- } def
-
-
- /printkernpairs /readPFMKernPairs load def
-
-
-
- /printcharmetrics {
- (StartCharMetrics ) print.to.ofi
- /PFBencoding currfont /Encoding get dup length array copy def
- /PFBcharstrings currfont /CharStrings get def
- PFBcharstrings length
- PFBcharstrings /.notdef known { 1 sub } if =to.ofi
- currfont 1000 scalefont setfont
-
-
- /was.inconsitent false def
- 0 1 255 {
- dup PFBencoding exch get
- PFBcharstrings exch known {
- pop
- }{
-
- PFBencoding exch /.notdef put
- /was.inconsitent true def
- } ifelse
- } for
- was.inconsitent {
- (Encoding array contains name(s) absent from CharStrings dictionary) =
- } if
-
- 0 1 255 {
- dup PFBencoding exch get
- dup /.notdef ne {
- exch dup printmetric
- }{
- pop pop
- } ifelse
- } for
-
-
- /xPFBencoding PFBcharstrings length dict def
- PFBencoding {
- xPFBencoding exch true put
- } forall
-
- /fontiter 0 def
- /TMPFontTemplate (TMP_FONT#000) def
- {
-
- /NewPFBencoding 256 array def
- 0 1 255 {
- NewPFBencoding exch /.notdef put
- } for
-
-
- /i 0 def
- PFBcharstrings {
- pop
- i 255 le {
- dup xPFBencoding exch known not {
- dup xPFBencoding exch true put
- NewPFBencoding i 3 -1 roll put
- /i i 1 add def
- }{
- pop
- } ifelse
- }{
- pop exit
- } ifelse
- } forall
- i 0 eq {exit} if
-
- currfont maxlength dict /NewTMPfont edef
- currfont {
- exch dup dup /FID ne exch /Encoding ne and {
- exch NewTMPfont 3 1 roll put
- }{
- pop pop
- } ifelse
- } forall
-
- /fontiter fontiter 1 add def
- TMPFontTemplate fontiter (000) cvs
- dup length TMPFontTemplate length exch sub exch putinterval
- /TMPFontName TMPFontTemplate cvn def
- NewTMPfont /FontName TMPFontName put
- NewTMPfont /Encoding NewPFBencoding put
-
- TMPFontName NewTMPfont definefont 1000 scalefont setfont
-
- 0 1 255 {
- dup NewPFBencoding exch get
- dup /.notdef ne {
- exch -1 printmetric
- }{
- pop pop exit
- } ifelse
- } for
- i 255 lt {exit} if
- } loop
- (EndCharMetrics) =to.ofi
- } def
-
-
-
- /printmetric {
- (C ) print.to.ofi =only.to.ofi
- ( ; WX ) print.to.ofi
- onechar 0 3 -1 roll put
- onechar stringwidth pop round cvi =only.to.ofi
- ( ; N ) print.to.ofi =only.to.ofi
- ( ; B ) print.to.ofi
- newpath 0 0 moveto
- onechar false charpath flattenpath pathbbox
- newpath
- round cvi /ury edef round cvi /urx edef
- round cvi /lly edef round cvi /llx edef
- ury lly eq {/ury 0 def /lly 0 def} if
- urx llx eq {/urx 0 def /llx 0 def} if
- llx =only.to.ofi ( ) print.to.ofi lly =only.to.ofi ( ) print.to.ofi
- urx =only.to.ofi ( ) print.to.ofi ury =only.to.ofi ( ) print.to.ofi
- (;) =to.ofi
- } def
-
- /printinfoitem {
- 3 1 roll 2 copy known {
- get dup type /stringtype ne { =string cvs } if exch
- print.to.ofi ( ) print.to.ofi =to.ofi
- }{
- pop pop pop
- } ifelse
- } def
-
- /printfontinfo {
- (Comment AFM Generated by Ghostscript/pf2afm) =to.ofi
- currfont /FontName (FontName) printinfoitem
-
- currfont /FontInfo get
- dup /FullName (FullName) printinfoitem
- dup /FamilyName (FamilyName) printinfoitem
- dup /Weight (Weight) printinfoitem
- dup /Notice (Notice) printinfoitem
- dup /ItalicAngle (ItalicAngle) printinfoitem
- dup /isFixedPitch (IsFixedPitch) printinfoitem
- dup /UnderlinePosition (UnderlinePosition) printinfoitem
- dup /UnderlineThickness (UnderlineThickness) printinfoitem
- /version (Version) printinfoitem
-
- (EncodingScheme FontSpecific) =to.ofi
-
- (FontBBox) print.to.ofi
- currfont /FontBBox get {
- ( ) print.to.ofi round cvi =only.to.ofi
- } forall
- eolch print.to.ofi
-
- currPFMfile () ne {
- PFMdict
- dup /PFMCapHeight (CapHeight) printinfoitem
- dup /PFMXHeight (XHeight) printinfoitem
- dup /PFMLowerCaseDescent (Descender) printinfoitem
- /PFMLowerCaseAscent (Ascender) printinfoitem
- } if
- } def
-
- /readPFBfile {
-
- /oldFontDirectory FontDirectory dup length dict copy def
- isPFB {
- (r) file true /PFBDecode filter cvx
- mark exch exec
- }{
- (r) file mark exch run
- } ifelse
- cleartomark
-
- /newFontDirectory FontDirectory dup length dict copy def
-
- oldFontDirectory {pop newFontDirectory exch undef} forall
- newFontDirectory length 1 ne {
- newFontDirectory length =
- (Weird PFB file?\n) printquit
- } if
- newFontDirectory {pop} forall
- findfont /currfont edef
- } def
-
- /readPFMfile {
- dup () ne {
- (r) file /currPFMfile edef
- 10 dict dup /PFMdict edef begin
- readPFMheader
- readPFMExtMetric
- end
- }{
- pop /currPFMfile () def
- } ifelse
- } def
-
-
-
-
- /printafm {
- readPFBfile
- readPFMfile
- (StartFontMetrics 2.0) =to.ofi
- printfontinfo
- printcharmetrics
- printkernpairs
- (EndFontMetrics) =to.ofi
- } def
-
- /pfa_pfb_dict <<
- /.pfb /pfbn
- /.pfB /pfbn
- /.pFb /pfbn
- /.pFB /pfbn
- /.Pfb /pfbn
- /.PfB /pfbn
- /.PFb /pfbn
- /.PFB /pfbn
-
- /.pfa /pfan
- /.pfA /pfan
- /.pFa /pfan
- /.pFA /pfan
- /.Pfa /pfan
- /.PfA /pfan
- /.PFa /pfan
- /.PFA /pfan
- >> readonly def
-
-
- /pfa_or_pfb? {
- dup length 4 lt {
- pop //false
- } {
- dup length 4 sub 4 getinterval //pfa_pfb_dict exch .knownget
- } ifelse
- } bind def
-
-
-
- /makeafm {
- count 0 eq {(Missing font file name\n) printquit} if
- /ifn edef
- ifn length 0 eq {(Empty font file name\n) printquit} if
-
-
-
- /pfbn () def /pfan () def /pfmn () def
- [ t1_glyph_equivalence { pop } forall ] {
- t1_glyph_equivalence exch undef
- } forall
- ifn pfa_or_pfb? {
- ifn dup length string copy def
- ifn dup length 4 sub 0 exch getinterval /ifn edef
- } if
- pfbn () eq pfan () eq and dup {
- /pfbn ifn (.pfb) concatstrings def
- } if
- pfbn () ne {
- pfbn status {pop pop pop pop /isPFB true def}{/pfbn () def} ifelse
- } if
- pfbn () eq and {
- /pfan ifn (.pfa) concatstrings def
- } if
- pfan () ne {
- pfan status {pop pop pop pop /isPFB false def}{/pfan () def} ifelse
- } if
-
- pfbn () eq pfan () eq and {
- (Neither pfa nor pfb found\n) printquit
- } if
-
- /ofn ifn (.afm) concatstrings def
- ofn status {
- pop pop pop pop (Resulting file exists\n) printquit
- } if
- /ofi ofn (w) file def
-
- /pfmn ifn (.pfm) concatstrings def
- pfmn status {
- pop pop pop pop
- }{
- () pfmn {
- (/) search dup not { pop (\\) search } if {
- 4 -1 roll exch concatstrings exch concatstrings exch
- }{
- exit
- } ifelse
- } loop
- (pfm/) exch concatstrings concatstrings
- dup status {
- pop pop pop pop /pfmn edef
- }{
- pop /pfmn () def (pfm file not found -- ignored\n) print
- } ifelse
- } ifelse
- //systemdict /.setsafe known {
- <<
- /PermitFileReading
- [ pfmn dup length 0 eq { pop } if
- isPFB {pfbn}{pfan} ifelse
- ]
- /PermitFileWriting [ ]
- /PermitFileControl [ ]
- >> setuserparams
- .locksafe
- } if
-
-
- pfmn
- isPFB {pfbn}{pfan} ifelse
- printafm
-
- } def
-
-
- [ shellarguments
- { ] dup length 1 eq {
- 0 get makeafm
- }{
- (This is PF2AFM -- AFM generator \(ver. 1.00\)\n) print
- (Usage: gs [-dNODISPLAY] -- pf2afm.ps disk_font_name\n) printquit
- } ifelse
- }
- {pop}
- ifelse
|