From 576b4eee42df25b2a3c895ae2c9c45cf5ad0aa2a Mon Sep 17 00:00:00 2001 From: Colin Rofls Date: Wed, 13 Sep 2023 16:38:27 -0400 Subject: [PATCH] [write-fonts] Consistent PairPos split range semantics We were using inclusive ranges in format 1 but exclusive ranges in format 2; now we're using exclusive ranges in both. --- write-fonts/src/graph/splitting.rs | 30 ++++++++++++++---------------- 1 file changed, 14 insertions(+), 16 deletions(-) diff --git a/write-fonts/src/graph/splitting.rs b/write-fonts/src/graph/splitting.rs index b623264f0..9aba00ea5 100644 --- a/write-fonts/src/graph/splitting.rs +++ b/write-fonts/src/graph/splitting.rs @@ -158,28 +158,28 @@ fn split_pair_pos_format_1(graph: &mut Graph, subtable: ObjectId) -> Option TableData { +fn split_off_ppf1(graph: &mut Graph, subtable: ObjectId, start: usize, end: usize) -> TableData { let coverage = graph.objects[&subtable].offsets.first().unwrap().object; let coverage = graph.objects.get(&coverage).unwrap(); let coverage = coverage.reparse::().unwrap(); - let n_pair_sets = (end - start) + 1; - let new_coverage = split_coverage(&coverage, start, end); + let n_pair_sets = end - start; + let new_coverage = split_coverage(&coverage, start as u16, end as u16); let new_cov_id = graph.add_object(new_coverage); let data = &graph.objects[&subtable]; @@ -191,11 +191,8 @@ fn split_off_ppf1(graph: &mut Graph, subtable: ObjectId, start: u16, end: u16) - new_ppf1.add_offset(new_cov_id, 2, 0); new_ppf1.write(table.value_format1()); new_ppf1.write(table.value_format2()); - new_ppf1.write(n_pair_sets); - for off in data.offsets[1 + start as usize..] - .iter() - .take(n_pair_sets as _) - { + new_ppf1.write(n_pair_sets as u16); + for off in data.offsets[1 + start..].iter().take(n_pair_sets as _) { new_ppf1.add_offset(off.object, 2, 0) } new_ppf1 @@ -468,13 +465,13 @@ fn copy_value_rec( fn split_coverage(coverage: &rlayout::CoverageTable, start: u16, end: u16) -> TableData { assert!(start <= end); - let len = (end - start) + 1; + let len = end - start; let mut data = TableData::default(); match coverage { rlayout::CoverageTable::Format1(table) => { data.write(1u16); data.write(len); - for gid in &table.glyph_array()[start as usize..=end as usize] { + for gid in &table.glyph_array()[start as usize..end as usize] { data.write(gid.get()); } } @@ -483,7 +480,7 @@ fn split_coverage(coverage: &rlayout::CoverageTable, start: u16, end: u16) -> Ta let records = table .range_records() .iter() - .filter_map(|record| split_range_record(record, start, end)) + .filter_map(|record| split_range_record(record, start, end - 1)) .collect::>(); data.write(2u16); data.write(records.len() as u16); @@ -497,6 +494,7 @@ fn split_coverage(coverage: &rlayout::CoverageTable, start: u16, end: u16) -> Ta data } +// NOTE: range records use inclusive ranges, everything else here is exclusive fn split_range_record( record: &rlayout::RangeRecord, start: u16,