class TTFunk::Subset::Unicode8Bit

limits number of characters so that the could be encoded by a single byte.
An 8-bit Unicode-based subset. It can include any Unicode character but

def covers?(character)

Returns:
  • (Boolean) -

Parameters:
  • character (Integer) -- Unicode codepoint
def covers?(character)
  @unicodes.key?(character) || @next < 256
end

def from_unicode(character)

Returns:
  • (Integer) -

Parameters:
  • character (Integer) -- Unicode codepoint
def from_unicode(character)
  @unicodes[character]
end

def includes?(character)

Returns:
  • (Boolean) -

Parameters:
  • character (Integer) -- Unicode codepoint
def includes?(character)
  @unicodes.key?(character)
end

def initialize(original)

Parameters:
  • original (TTFunk::File) --
def initialize(original)
  super
  @subset = { 0x20 => 0x20 }
  @unicodes = { 0x20 => 0x20 }
  @next = 0x21 # apparently, PDF's don't like to use chars between 0-31
end

def new_cmap_table

Returns:
  • (TTFunk::Table::Cmap) -
def new_cmap_table
  @new_cmap_table ||=
    begin
      mapping =
        @subset.each_with_object({}) do |(code, unicode), map|
          map[code] = unicode_cmap[unicode]
          map
        end
      # since we're mapping a subset of the unicode glyphs into an
      # arbitrary 256-character space, the actual encoding we're
      # using is irrelevant. We choose MacRoman because it's a 256-character
      # encoding that happens to be well-supported in both TTF and
      # PDF formats.
      TTFunk::Table::Cmap.encode(mapping, :mac_roman)
    end
end

def original_glyph_ids

Returns:
  • (Array) -
def original_glyph_ids
  ([0] + @unicodes.keys.map { |unicode| unicode_cmap[unicode] }).uniq.sort
end

def to_unicode_map

Returns:
  • (Hash{Integer => Integer}) -
def to_unicode_map
  @subset.dup
end

def unicode?

Returns:
  • (true) -
def unicode?
  true
end

def use(character)

Returns:
  • (void) -

Parameters:
  • character (Integer) -- Unicode codepoint
def use(character)
  unless @unicodes.key?(character)
    @subset[@next] = character
    @unicodes[character] = @next
    @next += 1
  end
end