Positions look good

This commit is contained in:
John Whitington 2023-06-12 16:27:46 +01:00
parent f0984ae589
commit 26473afbe0
1 changed files with 30 additions and 22 deletions

View File

@ -4,7 +4,7 @@ open Pdfio
let fontpack_experiment = false
let dbg = ref false
let dbg = ref true
type t =
{flags : int;
@ -80,12 +80,14 @@ let read_format_6_encoding_table b =
e -> failwith ("bad format 6 table: " ^ Printexc.to_string e ^ "\n")
let read_magic_formula b glyphIndexArrayStart seg segCount ro c sc =
if !dbg then Printf.printf "read_magic_formula: seg = %i, setCount = %i, ro = %i, c = %i, sc = %i\n" seg segCount ro c sc;
let position = seg - segCount + ro / 2 + (c - sc) in
let saved = b.pos_in () in
b.seek_in (glyphIndexArrayStart + position);
let result = b.input_byte () in
b.seek_in saved;
result
if !dbg then Printf.printf "position is %i\n" position;
b.input.seek_in (glyphIndexArrayStart + position);
b.bit <- 0;
b.bitsread <- 0;
b.currbyte <- 0;
read_short b
let read_format_4_encoding_table b =
let t = null_hash () in
@ -100,6 +102,7 @@ let read_format_4_encoding_table b =
let idDelta = Array.init segCount (fun _ -> read_ushort b) in
let idRangeOffset = Array.init segCount (fun _ -> read_ushort b) in
let glyphIndexArrayStart = b.input.pos_in () in
if !dbg then Printf.printf "glyphIndexArrayStart = %i\n" glyphIndexArrayStart;
if !dbg then
begin
Printf.printf "segCount = %i, searchRange = %i, entrySelector = %i, rangeShift = %i\n" segCount searchRange entrySelector rangeShift;
@ -113,26 +116,31 @@ let read_format_4_encoding_table b =
print_ints (Array.to_list idRangeOffset);
end;
for seg = 0 to segCount - 1 do
if !dbg then Printf.printf "Segment %i\n" seg;
let ec = endCodes.(seg) in
let sc = startCodes.(seg) in
let del = idDelta.(seg) in
let ro = idRangeOffset.(seg) in
if !dbg then Printf.printf "sc = %i, ec = %i, del = %i, ro = %i\n" sc ec del ro;
for c = sc to ec do
if !dbg then Printf.printf "Code %i\n" c;
if c != 0xFFFF then
if ro = 0 then
Hashtbl.add t c ((c + del) mod 65536)
else
begin
flprint "format 4 magic required\n";
let v = read_magic_formula b.input glyphIndexArrayStart seg segCount ro c sc in
let v = read_magic_formula b glyphIndexArrayStart seg segCount ro c sc in
if !dbg then Printf.printf "Value %i returned\n" v;
if v = 0
then Hashtbl.add t c ((c + del) mod 65536)
else Hashtbl.add t c ((v + del) mod 65536)
then Hashtbl.add t c (let r = (c + del) mod 65536 in if !dbg then Printf.printf "into hash %i\n" r; r)
else Hashtbl.add t c (let r = (v + del) mod 65536 in if !dbg then Printf.printf "into hash %i\n" r; r)
end
done
done;
t
let print_encoding_table (table : (int, int) Hashtbl.t) =
let print_encoding_table format (table : (int, int) Hashtbl.t) =
let unicodedata = Cpdfunicodedata.unicodedata () in
let unicodetable = Hashtbl.create 16000 in
iter
@ -140,12 +148,12 @@ let print_encoding_table (table : (int, int) Hashtbl.t) =
Hashtbl.add unicodetable x.Cpdfunicodedata.code_value x.Cpdfunicodedata.character_name)
unicodedata;
let l = sort compare (list_of_hashtbl table) in
Printf.printf "There are %i characters in this font\n" (length l)(*;
Printf.printf "Format table %i: There are %i characters in this font\n" format (length l);
iter
(fun (c, gi) ->
let str = Printf.sprintf "%04X" c in
Printf.printf "Char %s (%s) is at glyph index %i\n" str (Hashtbl.find unicodetable str) gi)
l*)
Printf.printf "Char %s (%s) is at glyph index %i\n" str (try Hashtbl.find unicodetable str with Not_found -> "Not_found") gi)
l
let read_encoding_table fmt length version b =
Printf.printf "********** format %i table has length, version %i, %i\n" fmt length version;
@ -154,7 +162,7 @@ let read_encoding_table fmt length version b =
if !dbg then Printf.printf "read_encoding_table: format 0\n";
let t = null_hash () in
for x = 0 to 255 do Hashtbl.add t x (read_byte b) done;
print_encoding_table t;
(*print_encoding_table 0 t;*)
t
| 4 ->
if !dbg then Printf.printf "read_encoding_table: format 4\n";
@ -519,7 +527,7 @@ let parse ?(subset=[]) data encoding =
let version = read_ushort b in
if !dbg then Printf.printf "subtable has format %i, length %i, version %i\n" fmt lngth version;
let got_glyphcodes = read_encoding_table fmt lngth version b in
if fmt = 4 then print_encoding_table got_glyphcodes;
if fmt = 4 then print_encoding_table 4 got_glyphcodes;
if fmt = 4 then Hashtbl.iter (Hashtbl.add !glyphcodes) got_glyphcodes
done;
end;