From e953d39f20070d89ca08acd59427c9e9cd813791 Mon Sep 17 00:00:00 2001 From: Ana Gelez Date: Wed, 17 Apr 2024 11:57:05 +0200 Subject: [PATCH] Make it possible to represent GID with a single byte in CMaps --- src/font.rs | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/src/font.rs b/src/font.rs index de43f23..6d2c961 100644 --- a/src/font.rs +++ b/src/font.rs @@ -657,11 +657,13 @@ pub struct UnicodeCmap { buf: Vec, mappings: Vec, count: i32, + /// Are the glyphs IDs represented using one byte only? + byte_gids: bool, } impl UnicodeCmap { /// Create a new, empty unicode character map. - pub fn new(name: Name, info: SystemInfo) -> Self { + pub fn new(name: Name, info: SystemInfo, byte_gids: bool) -> Self { // https://www.adobe.com/content/dam/acom/en/devnet/font/pdfs/5014.CIDFont_Spec.pdf let mut buf = Vec::new(); @@ -710,10 +712,14 @@ impl UnicodeCmap { // We just cover the whole unicode codespace. buf.extend(b"1 begincodespacerange\n"); - buf.extend(b"<0000> \n"); + if byte_gids { + buf.extend(b"<00> \n"); + } else { + buf.extend(b"<0000> \n"); + } buf.extend(b"endcodespacerange\n"); - Self { buf, mappings: vec![], count: 0 } + Self { buf, mappings: vec![], count: 0, byte_gids } } /// Add a mapping from a glyph ID to a codepoint. @@ -728,7 +734,11 @@ impl UnicodeCmap { codepoints: impl IntoIterator, ) { self.mappings.push(b'<'); - self.mappings.push_hex_u16(glyph); + if self.byte_gids { + self.mappings.push_hex(glyph as u8); + } else { + self.mappings.push_hex_u16(glyph); + } self.mappings.extend(b"> <"); for c in codepoints {