Module: TTFunk::Table::Cmap::Format06

Defined in:
lib/ttfunk/table/cmap/format06.rb

Overview

Format 6: Trimmed table mapping.

This module conditionally extends Subtable.

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#code_mapHash{Integer => Integer} (readonly)

Code map.

Returns:

  • (Hash{Integer => Integer})
Source Code
lib/ttfunk/table/cmap/format06.rb, line 16
16
def code_map
17
  @code_map
18
end

#languageInteger (readonly)

Language.

Returns:

  • (Integer)
Source Code
lib/ttfunk/table/cmap/format06.rb, line 12
12
def language
13
  @language
14
end

Class Method Details

.encode(charmap) ⇒ Hash

Encode the encoding record to format 6.

Parameters:

  • charmap (Hash{Integer => Integer})

    a hash mapping character codes to glyph IDs from the original font.

Returns:

  • (Hash)
    • :charmap (Hash{Integer => Hash}) keys are the characrers in charset, values are hashes:
      • :old (Integer) - glyph ID in the original font.
      • :new (Integer) - glyph ID in the subset font. that maps the characters in charmap to a
    • :subtable (String) - serialized encoding record.
    • :max_glyph_id (Integer) - maximum glyph ID in the new font.
Source Code
lib/ttfunk/table/cmap/format06.rb, line 30
30
def self.encode(charmap)
31
  next_id = 0
32
  glyph_map = { 0 => 0 }
33
34
  sorted_chars = charmap.keys.sort
35
  low_char = sorted_chars.first
36
  high_char = sorted_chars.last
37
  entry_count = 1 + high_char - low_char
38
  glyph_indexes = Array.new(entry_count, 0)
39
40
  new_map =
41
    charmap.keys.sort.each_with_object({}) do |code, map|
42
      glyph_map[charmap[code]] ||= next_id += 1
43
      map[code] = { old: charmap[code], new: glyph_map[charmap[code]] }
44
      glyph_indexes[code - low_char] = glyph_map[charmap[code]]
45
    end
46
47
  subtable = [
48
    6, 10 + (entry_count * 2), 0, low_char, entry_count, *glyph_indexes,
49
  ].pack('n*')
50
51
  { charmap: new_map, subtable: subtable, max_glyph_id: next_id + 1 }
52
end

Instance Method Details

#[](code) ⇒ Integer

Get glyph ID for character code.

Parameters:

  • code (Integer)

    character code.

Returns:

  • (Integer)

    glyph ID.

Source Code
lib/ttfunk/table/cmap/format06.rb, line 58
58
def [](code)
59
  @code_map[code] || 0
60
end

#supported?true

Is this encoding record format supported?

Returns:

  • (true)
Source Code
lib/ttfunk/table/cmap/format06.rb, line 65
65
def supported?
66
  true
67
end