addTable.py |
|
403 |
ArabicPUASimplified.txt |
|
10765 |
ArabicPUATraditional.txt |
|
13768 |
check-c-linkage-decls.py |
|
1289 |
check-externs.py |
|
675 |
check-header-guards.py |
|
1177 |
check-includes.py |
|
1732 |
check-libstdc++.py |
|
1205 |
check-release-notes.py |
|
591 |
check-static-inits.py |
|
1807 |
check-symbols.py |
|
3537 |
failing-alloc.c |
Based on https://software.intel.com/content/www/us/en/develop/articles/fast-random-number-generator-on-the-intel-pentiumr-4-processor.html |
1908 |
fix_get_types.py |
|
388 |
gen-arabic-joining-list.py |
usage: ./gen-arabic-joining-table.py ArabicShaping.txt Scripts.txt
Input files:
* https://unicode.org/Public/UCD/latest/ucd/ArabicShaping.txt
* https://unicode.org/Public/UCD/latest/ucd/Scripts.txt
|
2402 |
gen-arabic-pua.py |
usage: ./gen-arabic-pua.py
|
873 |
gen-arabic-table.py |
usage: ./gen-arabic-table.py ArabicShaping.txt UnicodeData.txt Blocks.txt
Input files:
* https://unicode.org/Public/UCD/latest/ucd/ArabicShaping.txt
* https://unicode.org/Public/UCD/latest/ucd/UnicodeData.txt
* https://unicode.org/Public/UCD/latest/ucd/Blocks.txt
|
10092 |
gen-def.py |
hb_shape_justify
hb_subset_input_override_name_table
hb_subset_cff_get_charstring_data
hb_subset_cff_get_charstrings_index
hb_subset_cff2_get_charstring_data
hb_subset_cff2_get_charstrings_index
|
1082 |
gen-emoji-table.py |
usage: ./gen-emoji-table.py emoji-data.txt emoji-test.txt
Input file:
* https://www.unicode.org/Public/UCD/latest/ucd/emoji/emoji-data.txt
* https://www.unicode.org/Public/emoji/latest/emoji-test.txt
|
2447 |
gen-harfbuzzcc.py |
|
772 |
gen-hb-version.py |
|
1171 |
gen-indic-table.py |
usage: ./gen-indic-table.py IndicSyllabicCategory.txt IndicPositionalCategory.txt Blocks.txt
Input files:
* https://unicode.org/Public/UCD/latest/ucd/IndicSyllabicCategory.txt
* https://unicode.org/Public/UCD/latest/ucd/IndicPositionalCategory.txt
* https://unicode.org/Public/UCD/latest/ucd/Blocks.txt
|
17498 |
gen-os2-unicode-ranges.py |
Generates the code for a sorted unicode range array as used in hb-ot-os2-unicode-ranges.hh
Input is a tab separated list of unicode ranges from the otspec
(https://docs.microsoft.com/en-us/typography/opentype/spec/os2#ur).
|
1239 |
gen-ragel-artifacts.py |
|
700 |
gen-tag-table.py |
Generator of the mapping from OpenType tags to BCP 47 tags and vice
versa.
It creates a ``const LangTag[]``, matching the tags from the OpenType
languages system tag list to the language subtags of the BCP 47 language
subtag registry, with some manual adjustments. The mappings are
supplemented with macrolanguages' sublanguages and retired codes'
replacements, according to BCP 47 and some manual additions where BCP 47
omits a retired code entirely.
Also generated is a function, ``hb_ot_ambiguous_tag_to_language``,
intended for use by ``hb_ot_tag_to_language``. It maps OpenType tags
back to BCP 47 tags. Ambiguous OpenType tags (those that correspond to
multiple BCP 47 tags) are listed here, except when the alphabetically
first BCP 47 tag happens to be the chosen disambiguated tag. In that
case, the fallback behavior will choose the right tag anyway.
usage: ./gen-tag-table.py languagetags language-subtag-registry
Input files:
* https://docs.microsoft.com/en-us/typography/opentype/spec/languagetags
* https://www.iana.org/assignments/language-subtag-registry/language-subtag-registry
|
37607 |
gen-ucd-table.py |
usage: ./gen-ucd-table [--rust] ucd.nounihan.grouped.xml [/path/to/hb-script-list.h]
Input file:
* https://unicode.org/Public/UCD/latest/ucdxml/ucd.nounihan.grouped.zip
|
7707 |
gen-use-table.py |
usage: ./gen-use-table.py IndicSyllabicCategory.txt IndicPositionalCategory.txt ArabicShaping.txt DerivedCoreProperties.txt UnicodeData.txt Blocks.txt Scripts.txt IndicSyllabicCategory-Additional.txt IndicPositionalCategory-Additional.txt
Input files:
* https://unicode.org/Public/UCD/latest/ucd/IndicSyllabicCategory.txt
* https://unicode.org/Public/UCD/latest/ucd/IndicPositionalCategory.txt
* https://unicode.org/Public/UCD/latest/ucd/ArabicShaping.txt
* https://unicode.org/Public/UCD/latest/ucd/DerivedCoreProperties.txt
* https://unicode.org/Public/UCD/latest/ucd/UnicodeData.txt
* https://unicode.org/Public/UCD/latest/ucd/Blocks.txt
* https://unicode.org/Public/UCD/latest/ucd/Scripts.txt
* ms-use/IndicSyllabicCategory-Additional.txt
* ms-use/IndicPositionalCategory-Additional.txt
|
15145 |
gen-vowel-constraints.py |
Generator of the function to prohibit certain vowel sequences.
It creates ``_hb_preprocess_text_vowel_constraints``, which inserts dotted
circles into sequences prohibited by the USE script development spec.
This function should be used as the ``preprocess_text`` of an
``hb_ot_shaper_t``.
usage: ./gen-vowel-constraints.py ms-use/IndicShapingInvalidCluster.txt Scripts.txt
Input file:
* https://unicode.org/Public/UCD/latest/ucd/Scripts.txt
|
7634 |
graph |
|
|
harfbuzz-cairo.pc.in |
|
299 |
harfbuzz-config.cmake.in |
|
1499 |
harfbuzz-gobject.pc.in |
|
291 |
harfbuzz-icu.pc.in |
|
287 |
harfbuzz-subset.cc |
|
2121 |
harfbuzz-subset.pc.in |
|
265 |
harfbuzz.cc |
|
1907 |
harfbuzz.pc.in |
|
293 |
hb-aat-layout-ankr-table.hh |
ankr -- Anchor Point
https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6ankr.html
|
2788 |
hb-aat-layout-bsln-table.hh |
bsln -- Baseline
https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6bsln.html
|
4636 |
hb-aat-layout-common.hh |
Unused. For debug tracing only. |
40248 |
hb-aat-layout-feat-table.hh |
feat -- Feature Name
https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6feat.html
|
7972 |
hb-aat-layout-just-table.hh |
just -- Justification
https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6just.html
|
12997 |
hb-aat-layout-kerx-table.hh |
kerx -- Extended Kerning
https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6kerx.html
|
35501 |
hb-aat-layout-morx-table.hh |
morx -- Extended Glyph Metamorphosis
https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6morx.html
https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6mort.html
|
45683 |
hb-aat-layout-opbd-table.hh |
opbd -- Optical Bounds
https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6opbd.html
|
5236 |
hb-aat-layout-trak-table.hh |
trak -- Tracking
https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6trak.html
|
8011 |
hb-aat-layout.cc |
hb_aat_apply_context_t
|
27149 |
hb-aat-layout.h |
|
57382 |
hb-aat-layout.hh |
https://developer.apple.com/documentation/coretext/1508745-ctfontcreatewithgraphicsfont |
2434 |
hb-aat-ltag-table.hh |
ltag -- Language Tag
https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6ltag.html
|
2650 |
hb-aat-map.cc |
Special case: Chain::compile_flags will fall back to the deprecated version of
small-caps if necessary, so we need to check for that possibility.
https://github.com/harfbuzz/harfbuzz/issues/2307 |
5994 |
hb-aat-map.hh |
For stable sorting only. |
3512 |
hb-aat.h |
HB_AAT_H |
1243 |
hb-algs.hh |
Flags
|
48658 |
hb-alloc-pool.hh |
Memory pool for persistent small- to medium-sized allocations.
Some AI musings on this, not necessarily true:
This is a very simple implementation, but it's good enough for our
purposes. It's not thread-safe. It's not very fast. It's not
very memory efficient. It's not very cache efficient. It's not
very anything efficient. But it's simple and it works. And it's
good enough for our purposes. If you need something more
sophisticated, use a real allocator. Or use a real language. |
3569 |
hb-array.hh |
Constructors.
|
15097 |
hb-atomic.hh |
Atomic integers and pointers.
|
9142 |
hb-bimap.hh |
Bi-directional map |
5411 |
hb-bit-page.hh |
Compiler-assisted vectorization. |
12054 |
hb-bit-set-invertible.hh |
Might return false if array looks unsorted.
Used for faster rejection of corrupt data. |
10657 |
hb-bit-set.hh |
Allocations successful |
28516 |
hb-bit-vector.hh |
|
5355 |
hb-blob.cc |
HAVE_UNISTD_H |
20476 |
hb-blob.h |
hb_memory_mode_t:
@HB_MEMORY_MODE_DUPLICATE: HarfBuzz immediately makes a copy of the data.
@HB_MEMORY_MODE_READONLY: HarfBuzz client will never modify the data,
and HarfBuzz will never modify the data.
@HB_MEMORY_MODE_WRITABLE: HarfBuzz client made a copy of the data solely
for HarfBuzz, so HarfBuzz may modify the data.
@HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITABLE: See above
Data type holding the memory modes available to
client programs.
Regarding these various memory-modes:
- In no case shall the HarfBuzz client modify memory
that is passed to HarfBuzz in a blob. If there is
any such possibility, @HB_MEMORY_MODE_DUPLICATE should be used
such that HarfBuzz makes a copy immediately,
- Use @HB_MEMORY_MODE_READONLY otherwise, unless you really really
really know what you are doing,
- @HB_MEMORY_MODE_WRITABLE is appropriate if you really made a
copy of data solely for the purpose of passing to
HarfBuzz and doing that just once (no reuse!),
- If the font is mmap()ed, it's okay to use
@HB_MEMORY_MODE_READONLY_MAY_MAKE_WRITABLE, however, using that mode
correctly is very tricky. Use @HB_MEMORY_MODE_READONLY instead.
|
4731 |
hb-blob.hh |
hb_blob_t
|
2765 |
hb-buffer-deserialize-json.hh |
|
20147 |
hb-buffer-deserialize-json.rl |
|
4125 |
hb-buffer-deserialize-text-glyphs.hh |
|
15939 |
hb-buffer-deserialize-text-glyphs.rl |
|
3442 |
hb-buffer-deserialize-text-unicode.hh |
|
6504 |
hb-buffer-deserialize-text-unicode.rl |
|
2504 |
hb-buffer-serialize.cc |
hb_buffer_serialize_list_formats:
Returns a list of supported buffer serialization formats.
Return value: (transfer none):
A string array of buffer serialization formats. Should not be freed.
Since: 0.9.7
|
26321 |
hb-buffer-verify.cc |
Cannot perform this check without monotone clusters. |
13216 |
hb-buffer.cc |
SECTION: hb-buffer
@title: hb-buffer
@short_description: Input and output buffers
@include: hb.h
Buffers serve a dual role in HarfBuzz; before shaping, they hold
the input characters that are passed to hb_shape(), and after
shaping they hold the output glyphs.
The input buffer is a sequence of Unicode codepoints, with
associated attributes such as direction and script. The output
buffer is a sequence of glyphs, with associated attributes such
as position and cluster.
|
60701 |
hb-buffer.h |
hb_glyph_info_t:
@codepoint: either a Unicode code point (before shaping) or a glyph index
(after shaping).
@cluster: the index of the character in the original text that corresponds
to this #hb_glyph_info_t, or whatever the client passes to
hb_buffer_add(). More than one #hb_glyph_info_t can have the same
@cluster value, if they resulted from the same character (e.g. one
to many glyph substitution), and when more than one character gets
merged in the same glyph (e.g. many to one glyph substitution) the
#hb_glyph_info_t will have the smallest cluster value of them.
By default some characters are merged into the same cluster
(e.g. combining marks have the same cluster as their bases)
even if they are separate glyphs, hb_buffer_set_cluster_level()
allow selecting more fine-grained cluster handling.
The #hb_glyph_info_t is the structure that holds information about the
glyphs and their relation to input text.
|
31540 |
hb-buffer.hh |
Reserved for shapers' internal use. |
20754 |
hb-cache.hh |
Implements a lockfree and thread-safe cache for int->int functions,
using (optionally) _relaxed_ atomic integer operations.
The cache is a fixed-size array of 16-bit or 32-bit integers,
typically 256 elements.
The key is split into two parts: the cache index (high bits)
and the rest (low bits).
The cache index is used to index into the array. The array
member is a 16-bit or 32-bit integer that is used *both*
to store the low bits of the key, and the value.
The value is stored in the least significant bits of the integer.
The low bits of the key are stored in the most significant bits
of the integer.
A cache hit is detected by comparing the low bits of the key
with the high bits of the integer at the array position indexed
by the high bits of the key. If they match, the value is extracted
from the least significant bits of the integer and returned.
Otherwise, a cache miss is reported.
Cache operations (storage and retrieval) involve just a few
arithmetic operations and a single memory access.
|
3932 |
hb-cairo-utils.cc |
SVG currently. |
23650 |
hb-cairo-utils.hh |
HB_CAIRO_UTILS_H |
4364 |
hb-cairo.cc |
SECTION:hb-cairo
@title: hb-cairo
@short_description: Cairo integration
@include: hb-cairo.h
Functions for using HarfBuzz with the cairo library.
HarfBuzz supports using cairo for rendering.
|
33285 |
hb-cairo.h |
hb_cairo_font_init_func_t:
@font: The #hb_font_t being created
@scaled_font: The respective #cairo_scaled_font_t
@user_data: User data accompanying this method
The type of a virtual method to be called when a cairo
face created using hb_cairo_font_face_create_for_face()
creates an #hb_font_t for a #cairo_scaled_font_t.
Return value: the #hb_font_t value to use; in most cases same as @font
Since: 7.0.0
|
3097 |
hb-cff-interp-common.hh |
=== Dict operators === |
20035 |
hb-cff-interp-cs-common.hh |
call stack |
24089 |
hb-cff-interp-dict-common.hh |
an opstr and the parsed out dict value(s) |
4900 |
hb-cff1-interp-cs.hh |
PostScript-originated legacy opcodes (OpCode_add etc) are unsupported |
4296 |
hb-cff2-interp-cs.hh |
make up return or endchar op |
8655 |
hb-common.cc |
SECTION:hb-common
@title: hb-common
@short_description: Common data types
@include: hb.h
Common data types used across HarfBuzz are defined here.
|
32892 |
hb-common.h |
!__cplusplus |
13195 |
hb-config.hh |
Make test happy. |
4559 |
hb-coretext-font.cc |
|
16368 |
hb-coretext-shape.cc |
shaper
|
29851 |
hb-coretext.cc |
SECTION:hb-coretext
@title: hb-coretext
@short_description: CoreText integration
@include: hb-coretext.h
Functions for using HarfBuzz with the CoreText fonts.
|
18341 |
hb-coretext.h |
HB_CORETEXT_TAG_MORT:
The #hb_tag_t tag for the `mort` (glyph metamorphosis) table,
which holds AAT features.
For more information, see
https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6mort.html
|
2932 |
hb-coretext.hh |
HB_CORETEXT_HH |
1650 |
hb-cplusplus.hh |
|
6262 |
hb-debug.hh |
Global runtime options.
|
12805 |
hb-decycler.hh |
hb_decycler_t is an efficient cycle detector for graph traversal.
It's a simple tortoise-and-hare algorithm with a twist: it's
designed to detect cycles while traversing a graph in a DFS manner,
instead of just a linked list.
For Floyd's tortoise and hare algorithm, see:
https://en.wikipedia.org/wiki/Cycle_detection#Floyd's_tortoise_and_hare
hb_decycler_t is O(n) in the number of nodes in the DFS traversal
if there are no cycles. Unlike Floyd's algorithm, hb_decycler_t
can be used in a DFS traversal, where the graph is not a simple
linked list, but a tree with possible cycles. Like Floyd's algorithm,
it is constant-memory (~three pointers).
The decycler works by creating an implicit linked-list on the stack,
of the path from the root to the current node, and apply Floyd's
algorithm on that list as it goes.
The decycler is malloc-free, and as such, much faster to use than a
hb_set_t or hb_map_t equivalent.
The decycler detects cycles in the graph *eventually*, not *immediately*.
That is, it may not detect a cycle until the cycle is fully traversed,
even multiple times. See Floyd's algorithm analysis for details.
The implementation saves a pointer storage on the stack by combining
this->u.decycler and this->u.next into a union. This is possible because
at any point we only need one of those values. The invariant is that
after construction, and before destruction, of a node, the u.decycler
field is always valid. The u.next field is only valid when the node is
in the traversal path, parent to another node.
There are three method's:
- hb_decycler_node_t() constructor: Creates a new node in the traversal.
The constructor takes a reference to the decycler object and inserts
itself as the latest node in the traversal path, by advancing the hare
pointer, and for every other descent, advancing the tortoise pointer.
- ~hb_decycler_node_t() destructor: Restores the decycler object to its
previous state by removing the node from the traversal path.
- bool visit(uintptr_t value): Called on every node in the graph. Returns
true if the node is not part of a cycle, and false if it is. The value
parameter is used to detect cycles. It's the caller's responsibility
to ensure that the value is unique for each node in the graph.
The cycle detection is as simple as comparing the value to the value
held by the tortoise pointer, which is the Floyd's algorithm.
For usage examples see test-decycler.cc.
|
5451 |
hb-deprecated.h |
SECTION:hb-deprecated
@title: hb-deprecated
@short_description: Deprecated API
@include: hb.h
These API have been deprecated in favor of newer API, or because they
were deemed unnecessary.
|
13343 |
hb-directwrite-font.cc |
|
11940 |
hb-directwrite-shape.cc |
shaper face data
|
18958 |
hb-directwrite.cc |
SECTION:hb-directwrite
@title: hb-directwrite
@short_description: DirectWrite integration
@include: hb-directwrite.h
Functions for using HarfBuzz with DirectWrite fonts.
|
12397 |
hb-directwrite.h |
HB_DIRECTWRITE_H |
2136 |
hb-directwrite.hh |
DirectWrite font stream helpers
|
5725 |
hb-dispatch.hh |
Dispatch
|
2301 |
hb-draw.cc |
SECTION:hb-draw
@title: hb-draw
@short_description: Glyph drawing
@include: hb.h
Functions for drawing (extracting) glyph shapes.
The #hb_draw_funcs_t struct can be used with hb_font_draw_glyph().
|
14346 |
hb-draw.h |
hb_draw_state_t
@path_open: Whether there is an open path
@path_start_x: X component of the start of current path
@path_start_y: Y component of the start of current path
@current_x: X component of current point
@current_y: Y component of current point
Current drawing state.
Since: 4.0.0
|
10111 |
hb-draw.hh |
hb_draw_funcs_t
|
6274 |
hb-face-builder.cc |
face-builder: A face that has add_table().
|
8285 |
hb-face.cc |
SECTION:hb-face
@title: hb-face
@short_description: Font face objects
@include: hb.h
A font face is an object that represents a single face from within a
font family.
More precisely, a font face represents a single face in a binary font file.
Font faces are typically built from a binary blob and a face index.
Font faces are used to create fonts.
A font face can be created from a binary blob using hb_face_create().
The face index is used to select a face from a binary blob that contains
multiple faces. For example, a binary blob that contains both a regular
and a bold face can be used to create two font faces, one for each face
index.
|
25917 |
hb-face.h |
hb_face_t
|
6453 |
hb-face.hh |
hb_face_t
|
3141 |
hb-fallback-shape.cc |
shaper face data
|
3127 |
hb-features.h.in |
|
2661 |
hb-font.cc |
SECTION:hb-font
@title: hb-font
@short_description: Font objects
@include: hb.h
Functions for working with font objects.
A font object represents a font face at a specific size and with
certain other parameters (pixels-per-em, points-per-em, variation
settings) specified. Font objects are created from font face
objects, and are used as input to hb_shape(), among other things.
Client programs can optionally pass in their own functions that
implement the basic, lower-level queries of font objects. This set
of font functions is defined by the virtual methods in
#hb_font_funcs_t.
HarfBuzz provides a built-in set of lightweight default
functions for each method in #hb_font_funcs_t.
The default font functions are implemented in terms of the
#hb_font_funcs_t methods of the parent font object. This allows
client programs to override only the methods they need to, and
otherwise inherit the parent font's implementation, if any.
|
100087 |
hb-font.h |
hb_font_funcs_t
|
41731 |
hb-font.hh |
hb_font_funcs_t
|
33448 |
hb-fontations.h |
SECTION: hb-fontations
@title: hb-fontations
@short_description: Fontations integration
@include: hb-fontations.h
Functions for using HarfBuzz with
[Fontations](https://github.com/googlefonts/fontations/) fonts.
|
1715 |
hb-free-pool.hh |
Memory pool for persistent alloc/free of small objects.
Some AI musings on this, not necessarily true:
This is a very simple implementation, but it's good enough for our
purposes. It's not thread-safe. It's not very fast. It's not
very memory efficient. It's not very cache efficient. It's not
very anything efficient. But it's simple and it works. And it's
good enough for our purposes. If you need something more
sophisticated, use a real allocator. Or use a real language. |
2893 |
hb-ft-colr.hh |
|
18916 |
hb-ft.cc |
SECTION:hb-ft
@title: hb-ft
@short_description: FreeType integration
@include: hb-ft.h
Functions for using HarfBuzz with the FreeType library.
HarfBuzz supports using FreeType to provide face and
font data.
<note>Note that FreeType is not thread-safe, therefore these
functions are not thread-safe either.</note>
|
48917 |
hb-ft.h |
Note: FreeType is not thread-safe.
Hence, these functions are not either.
|
4839 |
hb-gdi.cc |
SECTION:hb-gdi
@title: hb-gdi
@short_description: GDI integration
@include: hb-gdi.h
Functions for using HarfBuzz with GDI fonts.
|
2534 |
hb-gdi.h |
HB_GDI_H |
1255 |
hb-geometry.hh |
|
9804 |
hb-glib.cc |
SECTION:hb-glib
@title: hb-glib
@short_description: GLib integration
@include: hb-glib.h
Functions for using HarfBuzz with the GLib library.
HarfBuzz supports using GLib to provide Unicode data, by attaching
GLib functions to the virtual methods in a #hb_unicode_funcs_t function
structure.
|
6053 |
hb-glib.h |
HB_GLIB_H |
1625 |
hb-gobject-enums.cc.tmpl |
|
2042 |
hb-gobject-enums.h.tmpl |
|
1675 |
hb-gobject-structs.cc |
SECTION:hb-gobject
@title: hb-gobject
@short_description: GObject integration support
@include: hb-gobject.h
Support for using HarfBuzz with the GObject library to provide
type data.
The types and functions listed here are solely a linkage between
HarfBuzz's public data types and the GTypes used by the GObject framework.
HarfBuzz uses GObject introspection to generate its Python bindings
(and potentially other language bindings); client programs should never need
to access the GObject-integration mechanics.
For client programs using the GNOME and GTK software stack, please see the
GLib and FreeType integration pages.
|
3662 |
hb-gobject-structs.h |
Object types |
4236 |
hb-gobject.h |
HB_GOBJECT_H |
1335 |
hb-graphite2.cc |
SECTION:hb-graphite2
@title: hb-graphite2
@short_description: Graphite2 integration
@include: hb-graphite2.h
Functions for using HarfBuzz with fonts that include Graphite features.
For Graphite features to work, you must be sure that HarfBuzz was compiled
with the `graphite2` shaping engine enabled. Currently, the default is to
not enable `graphite2` shaping.
|
12899 |
hb-graphite2.h |
HB_GRAPHITE2_TAG_SILF:
The #hb_tag_t tag for the `Silf` table, which holds Graphite
features.
For more information, see http://graphite.sil.org/
|
1723 |
hb-harfrust.cc |
buffer
|
5656 |
hb-icu.cc |
ICU extra semicolon, fixed since 65, https://github.com/unicode-org/icu/commit/480bec3 |
9560 |
hb-icu.h |
HB_ICU_H |
1525 |
hb-iter.hh |
Unified iterator object.
The goal of this template is to make the same iterator interface
available to all types, and make it very easy and compact to use.
hb_iter_tator objects are small, light-weight, objects that can be
copied by value. If the collection / object being iterated on
is writable, then the iterator returns lvalues, otherwise it
returns rvalues.
If iterator implementation implements operator!=, then it can be
used in range-based for loop. That already happens if the iterator
is random-access. Otherwise, the range-based for loop incurs
one traversal to find end(), which can be avoided if written
as a while-style for loop, or if iterator implements a faster
__end__() method. |
32067 |
hb-kbts.cc |
|
7852 |
hb-kern.hh |
namespace OT |
3608 |
hb-limits.hh |
Shaping more than a billion chars? Let us know! |
2981 |
hb-machinery.hh |
Casts
|
11456 |
hb-map.cc |
SECTION:hb-map
@title: hb-map
@short_description: Object representing integer to integer mapping
@include: hb.h
Map objects are integer-to-integer hash-maps. Currently they are
not used in the HarfBuzz public API, but are provided for client's
use if desired.
|
7866 |
hb-map.h |
HB_MAP_VALUE_INVALID:
Unset #hb_map_t value.
Since: 1.7.7
|
3347 |
hb-map.hh |
hb_hashmap_t
|
15371 |
hb-meta.hh |
C++ template meta-programming & fundamentals used with them.
|
11086 |
hb-ms-feature-ranges.hh |
Variations of this code exist in hb-coretext-shape.cc as well
as hb-aat-map.cc... |
7255 |
hb-multimap.hh |
hb_multimap_t
|
2378 |
hb-mutex.hh |
mutex |
4295 |
hb-null.hh |
Static pools
|
7992 |
hb-number-parser.hh |
Works only for n < 512 |
5390 |
hb-number-parser.rl |
|
3216 |
hb-number.cc |
Check if consumed whole buffer if is requested |
2414 |
hb-number.hh |
HB_NUMBER_HH |
1502 |
hb-object.hh |
Lockable set
|
8295 |
hb-open-file.hh |
The OpenType Font File
|
15729 |
hb-open-type.hh |
The OpenType Font File: Data Types
|
60726 |
hb-ot-cff-common.hh |
CFF offsets can technically be negative |
11038 |
hb-ot-cff1-std-str.hh |
Make checks happy. |
8612 |
hb-ot-cff1-table.cc |
SID to code |
23687 |
hb-ot-cff1-table.hh |
CFF -- Compact Font Format (CFF)
https://www.adobe.com/content/dam/acom/en/devnet/font/pdfs/5176.CFF.pdf
|
42938 |
hb-ot-cff2-table.cc |
include control points |
7193 |
hb-ot-cff2-table.hh |
CFF2 -- Compact Font Format (CFF) Version 2
https://docs.microsoft.com/en-us/typography/opentype/spec/cff2
|
16242 |
hb-ot-cmap-table.hh |
cmap -- Character to Glyph Index Mapping
https://docs.microsoft.com/en-us/typography/opentype/spec/cmap
|
66722 |
hb-ot-color.cc |
SECTION:hb-ot-color
@title: hb-ot-color
@short_description: OpenType Color Fonts
@include: hb-ot.h
Functions for fetching color-font information from OpenType font faces.
HarfBuzz supports `COLR`/`CPAL`, `sbix`, `CBDT`, and `SVG` color fonts.
|
9917 |
hb-ot-color.h |
Color palettes.
|
4471 |
hb-ot-deprecated.h |
https://github.com/harfbuzz/harfbuzz/issues/1734 |
4130 |
hb-ot-face-table-list.hh |
HB_OT_FACE_TABLE_LIST_HH |
4145 |
hb-ot-face.cc |
|
2085 |
hb-ot-face.hh |
hb_ot_face_t
|
2557 |
hb-ot-font.cc |
SECTION:hb-ot-font
@title: hb-ot-font
@short_description: OpenType font implementation
@include: hb-ot.h
Functions for using OpenType fonts with hb_shape(). Note that fonts returned
by hb_font_create() default to using these functions, so most clients would
never need to call these functions directly.
|
30620 |
hb-ot-font.h |
HB_OT_FONT_H |
1410 |
hb-ot-gasp-table.hh |
gasp -- Grid-fitting and Scan-conversion Procedure
https://docs.microsoft.com/en-us/typography/opentype/spec/gasp
|
2369 |
hb-ot-glyf-table.hh |
HB_OT_GLYF_TABLE_HH |
1367 |
hb-ot-hdmx-table.hh |
hdmx -- Horizontal Device Metrics
https://docs.microsoft.com/en-us/typography/opentype/spec/hdmx
|
5137 |
hb-ot-head-table.hh |
head -- Font Header
https://docs.microsoft.com/en-us/typography/opentype/spec/head
|
7713 |
hb-ot-hhea-table.hh |
hhea -- Horizontal Header
https://docs.microsoft.com/en-us/typography/opentype/spec/hhea
vhea -- Vertical Header
https://docs.microsoft.com/en-us/typography/opentype/spec/vhea
|
3406 |
hb-ot-hmtx-table.hh |
hmtx -- Horizontal Metrics
https://docs.microsoft.com/en-us/typography/opentype/spec/hmtx
vmtx -- Vertical Metrics
https://docs.microsoft.com/en-us/typography/opentype/spec/vmtx
|
15446 |
hb-ot-kern-table.hh |
kern -- Kerning
https://docs.microsoft.com/en-us/typography/opentype/spec/kern
https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6kern.html
|
12352 |
hb-ot-layout-base-table.hh |
BASE -- Baseline
https://docs.microsoft.com/en-us/typography/opentype/spec/base
|
26926 |
hb-ot-layout-common.hh |
IN/OUT |
149727 |
hb-ot-layout-gdef-table.hh |
HB_OT_LAYOUT_GDEF_TABLE_HH |
1349 |
hb-ot-layout-gpos-table.hh |
Out-of-class implementation for methods recursing |
3122 |
hb-ot-layout-gsub-table.hh |
Out-of-class implementation for methods recursing |
3697 |
hb-ot-layout-gsubgpos.hh |
Have we visited this lookup with the current set of glyphs? |
156022 |
hb-ot-layout-jstf-table.hh |
JstfModList -- Justification Modification List Tables
|
7249 |
hb-ot-layout.cc |
SECTION:hb-ot-layout
@title: hb-ot-layout
@short_description: OpenType Layout
@include: hb-ot.h
Functions for querying OpenType Layout features in the font face.
See the [OpenType specification](http://www.microsoft.com/typography/otspec/)
for details.
|
93143 |
hb-ot-layout.h |
HB_OT_TAG_BASE:
OpenType [Baseline Table](https://docs.microsoft.com/en-us/typography/opentype/spec/base).
|
19223 |
hb-ot-layout.hh |
kern
|
19846 |
hb-ot-map.cc |
Fetch script/language indices for GSUB/GPOS. We need these later to skip
features not available in either table and not waste precious bits for them. |
12733 |
hb-ot-map.hh |
should be first for our bsearch to work |
9787 |
hb-ot-math-table.hh |
The X or Y value in design units |
38094 |
hb-ot-math.cc |
SECTION:hb-ot-math
@title: hb-ot-math
@short_description: OpenType Math information
@include: hb-ot.h
Functions for fetching mathematics layout data from OpenType fonts.
HarfBuzz itself does not implement a math layout solution. The
functions and types provided can be used by client programs to access
the font data necessary for typesetting OpenType Math layout.
|
12300 |
hb-ot-math.h |
MATH
|
13761 |
hb-ot-maxp-table.hh |
maxp -- Maximum Profile
https://docs.microsoft.com/en-us/typography/opentype/spec/maxp
|
5178 |
hb-ot-meta-table.hh |
meta -- Metadata Table
https://docs.microsoft.com/en-us/typography/opentype/spec/meta
https://developer.apple.com/fonts/TrueType-Reference-Manual/RM06/Chap6meta.html
|
3956 |
hb-ot-meta.cc |
SECTION:hb-ot-meta
@title: hb-ot-meta
@short_description: OpenType Metadata
@include: hb-ot.h
Functions for fetching metadata from fonts.
|
2433 |
hb-ot-meta.h |
hb_ot_meta_tag_t:
@HB_OT_META_TAG_DESIGN_LANGUAGES: Design languages. Text, using only
Basic Latin (ASCII) characters. Indicates languages and/or scripts
for the user audiences that the font was primarily designed for.
@HB_OT_META_TAG_SUPPORTED_LANGUAGES: Supported languages. Text, using
only Basic Latin (ASCII) characters. Indicates languages and/or scripts
that the font is declared to be capable of supporting.
Known metadata tags from https://docs.microsoft.com/en-us/typography/opentype/spec/meta
Since: 2.6.0
|
2553 |
hb-ot-metrics.cc |
SECTION:hb-ot-metrics
@title: hb-ot-metrics
@short_description: OpenType Metrics
@include: hb-ot.h
Functions for fetching metrics from fonts.
|
15524 |
hb-ot-metrics.h |
hb_ot_metrics_tag_t:
@HB_OT_METRICS_TAG_HORIZONTAL_ASCENDER: horizontal ascender.
@HB_OT_METRICS_TAG_HORIZONTAL_DESCENDER: horizontal descender.
@HB_OT_METRICS_TAG_HORIZONTAL_LINE_GAP: horizontal line gap.
@HB_OT_METRICS_TAG_HORIZONTAL_CLIPPING_ASCENT: horizontal clipping ascent.
@HB_OT_METRICS_TAG_HORIZONTAL_CLIPPING_DESCENT: horizontal clipping descent.
@HB_OT_METRICS_TAG_VERTICAL_ASCENDER: vertical ascender.
@HB_OT_METRICS_TAG_VERTICAL_DESCENDER: vertical descender.
@HB_OT_METRICS_TAG_VERTICAL_LINE_GAP: vertical line gap.
@HB_OT_METRICS_TAG_HORIZONTAL_CARET_RISE: horizontal caret rise.
@HB_OT_METRICS_TAG_HORIZONTAL_CARET_RUN: horizontal caret run.
@HB_OT_METRICS_TAG_HORIZONTAL_CARET_OFFSET: horizontal caret offset.
@HB_OT_METRICS_TAG_VERTICAL_CARET_RISE: vertical caret rise.
@HB_OT_METRICS_TAG_VERTICAL_CARET_RUN: vertical caret run.
@HB_OT_METRICS_TAG_VERTICAL_CARET_OFFSET: vertical caret offset.
@HB_OT_METRICS_TAG_X_HEIGHT: x height.
@HB_OT_METRICS_TAG_CAP_HEIGHT: cap height.
@HB_OT_METRICS_TAG_SUBSCRIPT_EM_X_SIZE: subscript em x size.
@HB_OT_METRICS_TAG_SUBSCRIPT_EM_Y_SIZE: subscript em y size.
@HB_OT_METRICS_TAG_SUBSCRIPT_EM_X_OFFSET: subscript em x offset.
@HB_OT_METRICS_TAG_SUBSCRIPT_EM_Y_OFFSET: subscript em y offset.
@HB_OT_METRICS_TAG_SUPERSCRIPT_EM_X_SIZE: superscript em x size.
@HB_OT_METRICS_TAG_SUPERSCRIPT_EM_Y_SIZE: superscript em y size.
@HB_OT_METRICS_TAG_SUPERSCRIPT_EM_X_OFFSET: superscript em x offset.
@HB_OT_METRICS_TAG_SUPERSCRIPT_EM_Y_OFFSET: superscript em y offset.
@HB_OT_METRICS_TAG_STRIKEOUT_SIZE: strikeout size.
@HB_OT_METRICS_TAG_STRIKEOUT_OFFSET: strikeout offset.
@HB_OT_METRICS_TAG_UNDERLINE_SIZE: underline size.
@HB_OT_METRICS_TAG_UNDERLINE_OFFSET: underline offset.
Metric tags corresponding to [MVAR Value
Tags](https://docs.microsoft.com/en-us/typography/opentype/spec/mvar#value-tags)
Since: 2.6.0
|
6020 |
hb-ot-metrics.hh |
OUT. May be NULL. |
1363 |
hb-ot-name-language-static.hh |
Following two tables were generated by joining FreeType, FontConfig,
and OpenType specification language lists, then filled in missing
entries using:
https://docs.microsoft.com/en-us/windows/desktop/intl/language-identifier-constants-and-strings
|
16705 |
hb-ot-name-language.hh |
HB_OT_NAME_LANGUAGE_HH |
1391 |
hb-ot-name-table.hh |
HB_OT_NAME_TABLE_HH |
1232 |
hb-ot-name.cc |
SECTION:hb-ot-name
@title: hb-ot-name
@short_description: OpenType font name information
@include: hb-ot.h
Functions for fetching name strings from OpenType fonts.
|
6135 |
hb-ot-name.h |
HB_OT_NAME_ID_RESERVED = 15, |
5536 |
hb-ot-os2-table.hh |
OS/2 and Windows Metrics
https://docs.microsoft.com/en-us/typography/opentype/spec/os2
|
12805 |
hb-ot-os2-unicode-ranges.hh |
Note: The contents of this array was generated using gen-os2-unicode-ranges.py. |
10125 |
hb-ot-post-macroman.hh |
Make checks happy. |
5696 |
hb-ot-post-table-v2subset.hh |
post -- PostScript
https://docs.microsoft.com/en-us/typography/opentype/spec/post
|
5121 |
hb-ot-post-table.hh |
post -- PostScript
https://docs.microsoft.com/en-us/typography/opentype/spec/post
|
10247 |
hb-ot-shape-fallback.cc |
Thai / Lao need some per-character work. |
19677 |
hb-ot-shape-fallback.hh |
HB_OT_SHAPE_FALLBACK_HH |
1904 |
hb-ot-shape-normalize.cc |
HIGHLEVEL DESIGN:
This file exports one main function: _hb_ot_shape_normalize().
This function closely reflects the Unicode Normalization Algorithm,
yet it's different.
Each shaper specifies whether it prefers decomposed (NFD) or composed (NFC).
The logic however tries to use whatever the font can support.
In general what happens is that: each grapheme is decomposed in a chain
of 1:2 decompositions, marks reordered, and then recomposed if desired,
so far it's like Unicode Normalization. However, the decomposition and
recomposition only happens if the font supports the resulting characters.
The goals are:
- Try to render all canonically equivalent strings similarly. To really
achieve this we have to always do the full decomposition and then
selectively recompose from there. It's kinda too expensive though, so
we skip some cases. For example, if composed is desired, we simply
don't touch 1-character clusters that are supported by the font, even
though their NFC may be different.
- When a font has a precomposed character for a sequence but the 'ccmp'
feature in the font is not adequate, use the precomposed character
which typically has better mark positioning.
- When a font does not support a combining mark, but supports it precomposed
with previous base, use that. This needs the itemizer to have this
knowledge too. We need to provide assistance to the itemizer.
- When a font does not support a character but supports its canonical
decomposition, well, use the decomposition.
- The shapers can customize the compose and decompose functions to
offload some of their requirements to the normalizer. For example, the
Indic shaper may want to disallow recomposing of two matras.
|
15460 |
hb-ot-shape-normalize.hh |
buffer var allocations, used during the normalization process |
3365 |
hb-ot-shape.cc |
https://github.com/harfbuzz/harfbuzz/issues/2124 |
39434 |
hb-ot-shape.h |
TODO port to shape-plan / set. |
1972 |
hb-ot-shape.hh |
In the order that they are filled in. |
4496 |
hb-ot-shaper-arabic-fallback.hh |
Features ordered the same as the entries in shaping_table rows,
followed by rlig. Don't change.
We currently support one subtable per lookup, and one lookup
per feature. But we allow duplicate features, so we use that!
|
13157 |
hb-ot-shaper-arabic-joining-list.hh |
== Start of generated function == |
1076 |
hb-ot-shaper-arabic-pua.hh |
== Start of generated table == |
7509 |
hb-ot-shaper-arabic-table.hh |
== Start of generated table == |
24948 |
hb-ot-shaper-arabic-win1256.hh |
The macros in the first part of this file are generic macros that can
be used to define the bytes for OpenType table data in code in a
readable manner. We can move the macros to reside with their respective
struct types, but since we only use these to define one data table, the
Windows-1256 Arabic shaping table in this file, we keep them here.
|
9674 |
hb-ot-shaper-arabic.cc |
buffer var allocations |
24650 |
hb-ot-shaper-arabic.hh |
HB_OT_SHAPER_ARABIC_HH |
1648 |
hb-ot-shaper-default.cc |
collect_features |
2343 |
hb-ot-shaper-hangul.cc |
Hangul shaper |
13012 |
hb-ot-shaper-hebrew.cc |
Hebrew presentation-form shaping.
https://bugzilla.mozilla.org/show_bug.cgi?id=728866
Hebrew presentation forms with dagesh, for characters U+05D0..05EA;
Note that some letters do not have a dagesh presForm encoded.
|
5816 |
hb-ot-shaper-indic-machine.hh |
buffer var allocations |
43893 |
hb-ot-shaper-indic-machine.rl |
|
4399 |
hb-ot-shaper-indic-table.cc |
== Start of generated table == |
27475 |
hb-ot-shaper-indic.cc |
Indic shaper.
|
52457 |
hb-ot-shaper-indic.hh |
Visual positions in a syllable from left to right. |
1717 |
hb-ot-shaper-khmer-machine.hh |
buffer var allocations |
12157 |
hb-ot-shaper-khmer-machine.rl |
|
3505 |
hb-ot-shaper-khmer.cc |
Khmer shaper.
|
11022 |
hb-ot-shaper-myanmar-machine.hh |
buffer var allocations |
21456 |
hb-ot-shaper-myanmar-machine.rl |
|
4363 |
hb-ot-shaper-myanmar.cc |
Myanmar shaper.
|
10808 |
hb-ot-shaper-syllabic.cc |
Insert dottedcircle after possible Repha. |
3533 |
hb-ot-shaper-syllabic.hh |
HB_OT_SHAPER_SYLLABIC_HH |
1611 |
hb-ot-shaper-thai.cc |
Thai / Lao shaper |
12169 |
hb-ot-shaper-use-machine.hh |
buffer var allocations |
37116 |
hb-ot-shaper-use-machine.rl |
|
9115 |
hb-ot-shaper-use-table.hh |
== Start of generated table == |
54285 |
hb-ot-shaper-use.cc |
Universal Shaping Engine.
https://docs.microsoft.com/en-us/typography/script-development/use
|
14493 |
hb-ot-shaper-vowel-constraints.cc |
== Start of generated functions == |
11271 |
hb-ot-shaper-vowel-constraints.hh |
HB_OT_SHAPER_VOWEL_CONSTRAINTS_HH |
1465 |
hb-ot-shaper.hh |
buffer var allocations, used by all OT shapers |
11979 |
hb-ot-stat-table.hh |
STAT -- Style Attributes
https://docs.microsoft.com/en-us/typography/opentype/spec/stat
|
21191 |
hb-ot-tag-table.hh |
== Start of generated table == |
189876 |
hb-ot-tag.cc |
hb_script_t |
18546 |
hb-ot-var-avar-table.hh |
avar -- Axis Variations
https://docs.microsoft.com/en-us/typography/opentype/spec/avar
|
13596 |
hb-ot-var-common.hh |
https://docs.microsoft.com/en-us/typography/opentype/spec/otvarcommonformats#tuplevariationheader |
71837 |
hb-ot-var-cvar-table.hh |
cvar -- control value table (CVT) Variations
https://docs.microsoft.com/en-us/typography/opentype/spec/cvar
|
8654 |
hb-ot-var-fvar-table.hh |
fvar -- Font Variations
https://docs.microsoft.com/en-us/typography/opentype/spec/fvar
|
15594 |
hb-ot-var-gvar-table.hh |
gvar -- Glyph Variation Table
https://docs.microsoft.com/en-us/typography/opentype/spec/gvar
|
31938 |
hb-ot-var-hvar-table.hh |
dual as TSB |
15347 |
hb-ot-var-mvar-table.hh |
Four-byte tag identifying a font-wide measure. |
5728 |
hb-ot-var-varc-table.hh |
HB_OT_VAR_VARC_TABLE_HH |
1243 |
hb-ot-var.cc |
SECTION:hb-ot-var
@title: hb-ot-var
@short_description: OpenType Font Variations
@include: hb-ot.h
Functions for fetching information about OpenType Variable Fonts.
|
10501 |
hb-ot-var.h |
HB_OT_TAG_VAR_AXIS_ITALIC:
Registered tag for the roman/italic axis.
|
5209 |
hb-ot-vorg-table.hh |
VORG -- Vertical Origin Table
https://docs.microsoft.com/en-us/typography/opentype/spec/vorg
|
3721 |
hb-ot.h |
HB_OT_H |
1502 |
hb-outline.cc |
pacify compiler |
8484 |
hb-outline.hh |
HB_OUTLINE_HH |
2113 |
hb-paint-bounded.cc |
This file implements boundedness computation of COLRv1 fonts as described in:
https://learn.microsoft.com/en-us/typography/opentype/spec/colr#glyph-metrics-and-boundedness
|
6539 |
hb-paint-bounded.hh |
HB_PAINT_BOUNDED_HH |
2821 |
hb-paint-extents.cc |
This file implements bounds-extraction computation of COLRv1 fonts as described in:
https://learn.microsoft.com/en-us/typography/opentype/spec/colr#glyph-metrics-and-boundedness
|
7911 |
hb-paint-extents.hh |
Transform extents and push a new clip. |
3594 |
hb-paint.cc |
SECTION: hb-paint
@title: hb-paint
@short_description: Glyph painting
@include: hb.h
Functions for painting glyphs.
The main purpose of these functions is to paint (extract) color glyph layers
from the COLRv1 table, but the API works for drawing ordinary outlines and
images as well.
The #hb_paint_funcs_t struct can be used with hb_font_paint_glyph().
|
22762 |
hb-paint.h |
hb_paint_funcs_t:
Glyph paint callbacks.
The callbacks assume that the caller maintains a stack
of current transforms, clips and intermediate surfaces,
as evidenced by the pairs of push/pop callbacks. The
push/pop calls will be properly nested, so it is fine
to store the different kinds of object on a single stack.
Not all callbacks are required for all kinds of glyphs.
For rendering COLRv0 or non-color outline glyphs, the
gradient callbacks are not needed, and the composite
callback only needs to handle simple alpha compositing
(#HB_PAINT_COMPOSITE_MODE_SRC_OVER).
The paint-image callback is only needed for glyphs
with image blobs in the CBDT, sbix or SVG tables.
The custom-palette-color callback is only necessary if
you want to override colors from the font palette with
custom colors.
Since: 7.0.0
|
40140 |
hb-paint.hh |
^--- Add new callbacks here |
8957 |
hb-priority-queue.hh |
hb_priority_queue_t
Priority queue implemented as a binary heap. Supports extract minimum
and insert operations.
The priority queue is implemented as a binary heap, which is a complete
binary tree. The root of the tree is the minimum element. The heap
property is that the priority of a node is less than or equal to the
priority of its children. The heap is stored in an array, with the
children of node i stored at indices 2i + 1 and 2i + 2.
|
4658 |
hb-repacker.hh |
For a detailed writeup on the overflow resolution algorithm see:
docs/repacker.md
|
18120 |
hb-sanitize.hh |
Sanitize
=== Introduction ===
The sanitize machinery is at the core of our zero-cost font loading. We
mmap() font file into memory and create a blob out of it. Font subtables
are returned as a readonly sub-blob of the main font blob. These table
blobs are then sanitized before use, to ensure invalid memory access does
not happen. The toplevel sanitize API use is like, eg. to load the 'head'
table:
hb_blob_t *head_blob = hb_sanitize_context_t ().reference_table<OT::head> (face);
The blob then can be converted to a head table struct with:
const head *head_table = head_blob->as<head> ();
What the reference_table does is, to call hb_face_reference_table() to load
the table blob, sanitize it and return either the sanitized blob, or empty
blob if sanitization failed. The blob->as() function returns the null
object of its template type argument if the blob is empty. Otherwise, it
just casts the blob contents to the desired type.
Sanitizing a blob of data with a type T works as follows (with minor
simplification):
- Cast blob content to T*, call sanitize() method of it,
- If sanitize succeeded, return blob.
- Otherwise, if blob is not writable, try making it writable,
or copy if cannot be made writable in-place,
- Call sanitize() again. Return blob if sanitize succeeded.
- Return empty blob otherwise.
=== The sanitize() contract ===
The sanitize() method of each object type shall return `true` if it's safe to
call other methods of the object, and `false` otherwise.
Note that what sanitize() checks for might align with what the specification
describes as valid table data, but does not have to be. In particular, we
do NOT want to be pedantic and concern ourselves with validity checks that
are irrelevant to our use of the table. On the contrary, we want to be
lenient with error handling and accept invalid data to the extent that it
does not impose extra burden on us.
Based on the sanitize contract, one can see that what we check for depends
on how we use the data in other table methods. Ie. if other table methods
assume that offsets do NOT point out of the table data block, then that's
something sanitize() must check for (GSUB/GPOS/GDEF/etc work this way). On
the other hand, if other methods do such checks themselves, then sanitize()
does not have to bother with them (glyf/local work this way). The choice
depends on the table structure and sanitize() performance. For example, to
check glyf/loca offsets in sanitize() would cost O(num-glyphs). We try hard
to avoid such costs during font loading. By postponing such checks to the
actual glyph loading, we reduce the sanitize cost to O(1) and total runtime
cost to O(used-glyphs). As such, this is preferred.
The same argument can be made re GSUB/GPOS/GDEF, but there, the table
structure is so complicated that by checking all offsets at sanitize() time,
we make the code much simpler in other methods, as offsets and referenced
objects do not need to be validated at each use site.
|
15254 |
hb-script-list.h |
This file belongs to the middle of hb-common.h.
The reason it has been surgically extracted is because
FreeType imports types and enums from hb-common.h,
and since this enum is large and growing, we want to
make it easy to just copy the file over to FreeType.
https://github.com/harfbuzz/harfbuzz/issues/5271
|
20312 |
hb-serialize.hh |
Serialize
|
23593 |
hb-set-digest.hh |
The set-digests implement "filters" that support "approximate
member query". Conceptually these are like Bloom Filter and
Quotient Filter, however, much smaller, faster, and designed
to fit the requirements of our uses for glyph coverage queries.
Our filters are highly accurate if the lookup covers fairly local
set of glyphs, but fully flooded and ineffective if coverage is
all over the place.
The way these are used is that the filter is first populated by
a lookup's or subtable's Coverage table(s), and then when we
want to apply the lookup or subtable to a glyph, before trying
to apply, we ask the filter if the glyph may be covered. If it's
not, we return early. We can also match a digest against another
digest.
We use these filters at three levels:
- If the digest for all the glyphs in the buffer as a whole
does not match the digest for the lookup, skip the lookup.
- For each glyph, if it doesn't match the lookup digest,
skip it.
- For each glyph, if it doesn't match the subtable digest,
skip it.
The filter we use is a combination of three bits-pattern
filters. A bits-pattern filter checks a number of bits (5 or 6)
of the input number (glyph-id in most cases) and checks whether
its pattern is amongst the patterns of any of the accepted values.
The accepted patterns are represented as a "long" integer. Each
check is done using four bitwise operations only.
|
5454 |
hb-set.cc |
SECTION:hb-set
@title: hb-set
@short_description: Objects representing a set of integers
@include: hb.h
Set objects represent a mathematical set of integer values. They are
used in non-shaping APIs to query certain sets of characters or glyphs,
or other integer values.
|
13636 |
hb-set.h |
HB_SET_VALUE_INVALID:
Unset #hb_set_t value.
Since: 0.9.21
|
5054 |
hb-set.hh |
Might return false if array looks unsorted.
Used for faster rejection of corrupt data. |
7189 |
hb-shape-plan.cc |
SECTION:hb-shape-plan
@title: hb-shape-plan
@short_description: Object representing a shaping plan
@include: hb.h
Shape plans are an internal mechanism. Each plan contains state
describing how HarfBuzz will shape a particular text segment, based on
the combination of segment properties and the capabilities in the
font face in use.
Shape plans are not used for shaping directly, but can be queried to
access certain information about how shaping will perform, given a set
of specific input parameters (script, language, direction, features,
etc.).
Most client programs will not need to deal with shape plans directly.
|
16466 |
hb-shape-plan.h |
hb_shape_plan_t:
Data type for holding a shaping plan.
Shape plans contain information about how HarfBuzz will shape a
particular text segment, based on the segment's properties and the
capabilities in the font face in use.
Shape plans can be queried about how shaping will perform, given a set
of specific input parameters (script, language, direction, features,
etc.).
|
4121 |
hb-shape-plan.hh |
We don't carry a reference to face. |
2429 |
hb-shape.cc |
SECTION:hb-shape
@title: hb-shape
@short_description: Conversion of text strings into positioned glyphs
@include: hb.h
Shaping is the central operation of HarfBuzz. Shaping operates on buffers,
which are sequences of Unicode characters that use the same font and have
the same text direction, script, and language. After shaping the buffer
contains the output glyphs and their positions.
|
12862 |
hb-shape.h |
IN/OUT |
2344 |
hb-shaper-impl.hh |
HB_SHAPER_IMPL_HH |
1332 |
hb-shaper-list.hh |
HB_SHAPER_LIST_HH |
2011 |
hb-shaper.cc |
Reorder shaper list to prefer requested shapers. |
2985 |
hb-shaper.hh |
Type forward declaration. |
4622 |
hb-static.cc |
thread_local |
3480 |
hb-string-array.hh |
Make checks happy. |
2925 |
hb-style.cc |
SECTION:hb-style
@title: hb-style
@short_description: Font Styles
@include: hb.h
Functions for fetching style information from fonts.
|
3902 |
hb-style.h |
hb_style_tag_t:
@HB_STYLE_TAG_ITALIC: Used to vary between non-italic and italic.
A value of 0 can be interpreted as "Roman" (non-italic); a value of 1 can
be interpreted as (fully) italic.
@HB_STYLE_TAG_OPTICAL_SIZE: Used to vary design to suit different text sizes.
Non-zero. Values can be interpreted as text size, in points.
@HB_STYLE_TAG_SLANT_ANGLE: Used to vary between upright and slanted text. Values
must be greater than -90 and less than +90. Values can be interpreted as
the angle, in counter-clockwise degrees, of oblique slant from whatever the
designer considers to be upright for that font design. Typical right-leaning
Italic fonts have a negative slant angle (typically around -12)
@HB_STYLE_TAG_SLANT_RATIO: same as @HB_STYLE_TAG_SLANT_ANGLE expression as ratio.
Typical right-leaning Italic fonts have a positive slant ratio (typically around 0.2)
@HB_STYLE_TAG_WIDTH: Used to vary width of text from narrower to wider.
Non-zero. Values can be interpreted as a percentage of whatever the font
designer considers “normal width” for that font design.
@HB_STYLE_TAG_WEIGHT: Used to vary stroke thicknesses or other design details
to give variation from lighter to blacker. Values can be interpreted in direct
comparison to values for usWeightClass in the OS/2 table,
or the CSS font-weight property.
Defined by [OpenType Design-Variation Axis Tag Registry](https://docs.microsoft.com/en-us/typography/opentype/spec/dvaraxisreg).
Since: 3.0.0
|
3340 |
hb-subset-accelerator.hh |
HB_SUBSET_ACCELERATOR_HH |
3766 |
hb-subset-cff-common.cc |
Disable FDSelect format 0 for compatibility with fonttools which doesn't seem choose it.
Rarely any/much smaller than format 3 anyway. |
6730 |
hb-subset-cff-common.hh |
Used for writing a temporary charstring |
34658 |
hb-subset-cff1.cc |
a copy of a parsed out cff1_top_dict_values_t augmented with additional operators |
28232 |
hb-subset-cff2.cc |
dummy opcodes in CFF2. ignore |
19566 |
hb-subset-input.cc |
|
26384 |
hb-subset-input.hh |
HB_SUBSET_INPUT_HH |
4132 |
hb-subset-instancer-iup.cc |
This file is a straight port of the following:
https://github.com/fonttools/fonttools/blob/main/Lib/fontTools/varLib/iup.py
Where that file returns optimzied deltas vector, we return optimized
referenced point indices.
|
17458 |
hb-subset-instancer-iup.hh |
given contour points and deltas, optimize a set of referenced points within error
tolerance. Returns optimized referenced point indices |
2089 |
hb-subset-instancer-solver.cc |
This file is a straight port of the following:
https://github.com/fonttools/fonttools/blob/f73220816264fc383b8a75f2146e8d69e455d398/Lib/fontTools/varLib/instancer/solver.py
Where that file returns None for a triple, we return Triple{}.
This should be safe.
|
13861 |
hb-subset-instancer-solver.hh |
pre-normalized distances |
3827 |
hb-subset-plan-layout.cc |
Removes all tags from 'tags' that are not in filter. Additionally eliminates any duplicates.
Returns true if anything was removed (not including duplicates).
|
14300 |
hb-subset-plan-member-list.hh |
HB_SUBSET_PLAN_MEMBER_LIST_HH |
7597 |
hb-subset-plan-var.cc |
OUT |
14942 |
hb-subset-plan.cc |
OUT |
28847 |
hb-subset-plan.hh |
|
10179 |
hb-subset-serialize.cc |
hb_subset_serialize_or_fail:
@table_tag: tag of the table being packed, needed to allow table specific optimizations.
@hb_objects: raw array of struct hb_subset_serialize_object_t, which provides
object graph info
@num_hb_objs: number of hb_subset_serialize_object_t in the hb_objects array.
Given the input object graph info, repack a table to eliminate offset overflows and
serialize it into a continuous array of bytes. A nullptr is returned if the serializing attempt fails.
Table specific optimizations (eg. extension promotion in GSUB/GPOS) may be performed.
Passing HB_TAG_NONE will disable table specific optimizations.
Since: 10.2.0
|
2340 |
hb-subset-serialize.h |
hb_subset_serialize_link_t:
@width: offsetSize in bytes
@position: position of the offset field in bytes from
beginning of subtable
@objidx: index of subtable
Represents a link between two objects in the object graph
to be serialized.
Since: 10.2.0
|
2639 |
hb-subset-table-cff.cc |
hb_subset_cff_get_charstring_data:
@face: A face object
@glyph_index: Glyph index to get data for.
Returns the raw outline data from the CFF/CFF2 table associated with the given glyph index.
XSince: EXPERIMENTAL
|
3961 |
hb-subset-table-color.cc |
skip CBDT, handled by CBLC |
844 |
hb-subset-table-layout.cc |
|
927 |
hb-subset-table-other.cc |
skip hhea, handled by hmtx |
1663 |
hb-subset-table-var.cc |
|
1625 |
hb-subset-table.hh |
OUT |
6944 |
hb-subset.cc |
SECTION:hb-subset
@title: hb-subset
@short_description: Subsets font files.
@include: hb-subset.h
Subsetting reduces the codepoint coverage of font files and removes all data
that is no longer needed. A subset input describes the desired subset. The input is
provided along with a font to the subsetting operation. Output is a new font file
containing only the data specified in the input.
Currently most outline and bitmap tables are supported: glyf, CFF, CFF2, sbix,
COLR, and CBDT/CBLC. This also includes fonts with variable outlines via OpenType
variations. Notably EBDT/EBLC and SVG are not supported. Layout subsetting is supported
only for OpenType Layout tables (GSUB, GPOS, GDEF). Notably subsetting of graphite or AAT tables
is not yet supported.
Fonts with graphite or AAT tables may still be subsetted but will likely need to use the
retain glyph ids option and configure the subset to pass through the layout tables untouched.
|
13703 |
hb-subset.h |
hb_subset_input_t:
Things that change based on the input. Characters to keep, etc.
|
10488 |
hb-subset.hh |
HB_SUBSET_HH |
2467 |
hb-ucd-table.hh |
== Start of generated table == |
420689 |
hb-ucd.cc |
Copyright (C) 2012 Grigori Goronzy <greg@kinoho.net>
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted, provided that the above
copyright notice and this permission notice appear in all copies.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
7196 |
hb-unicode-emoji-table.hh |
== Start of generated table == |
3874 |
hb-unicode.cc |
SECTION: hb-unicode
@title: hb-unicode
@short_description: Unicode character property access
@include: hb.h
Unicode functions are used to access Unicode character properties.
With these functions, client programs can query various properties from
the Unicode Character Database for any code point, such as General
Category (gc), Script (sc), Canonical Combining Class (ccc), etc.
Client programs can optionally pass in their own Unicode functions
that implement the same queries. The set of functions available is
defined by the virtual methods in #hb_unicode_funcs_t.
HarfBuzz provides built-in default functions for each method in
#hb_unicode_funcs_t.
|
17313 |
hb-unicode.h |
HB_UNICODE_MAX:
Maximum valid Unicode code point.
Since: 1.9.0
|
22980 |
hb-unicode.hh |
hb_unicode_funcs_t
|
16921 |
hb-uniscribe.cc |
SECTION:hb-uniscribe
@title: hb-uniscribe
@short_description: Windows integration
@include: hb-uniscribe.h
Functions for using HarfBuzz with Windows fonts.
|
25090 |
hb-uniscribe.h |
HB_UNISCRIBE_H |
1391 |
hb-utf.hh |
Written to only accept well-formed sequences.
Based on ideas from ICU's U8_NEXT.
Generates one "replacement" for each ill-formed byte. |
11163 |
hb-vector.hh |
< 0 means allocation failed. |
18602 |
hb-version.h |
HB_VERSION_MAJOR:
The major component of the library version available at compile-time.
|
2597 |
hb-version.h.in |
|
2653 |
hb-wasm-api-blob.hh |
HB_WASM_API_BLOB_HH |
1453 |
hb-wasm-api-buffer.hh |
|
6054 |
hb-wasm-api-common.hh |
HB_WASM_API_COMMON_HH |
1444 |
hb-wasm-api-face.hh |
HB_WASM_API_FACE_HH |
2717 |
hb-wasm-api-font.hh |
|
7284 |
hb-wasm-api-list.hh |
Note: the array must be static defined since runtime will keep it after registration.
Also not const, because it modifies it (sorts it).
https://github.com/bytecodealliance/wasm-micro-runtime/blob/main/doc/export_native_api.md
TODO Allocate this lazily in _hb_wasm_init(). |
3950 |
hb-wasm-api-shape.hh |
Pre-conditions that make hb_shape_full() crash should be checked here. |
2148 |
hb-wasm-api.cc |
|
1465 |
hb-wasm-api.h |
#include "hb.h"
HB_BEGIN_DECLS
HB_END_DECLS
|
8063 |
hb-wasm-api.hh |
Check object type. |
3826 |
hb-wasm-shape.cc |
Compile wasm-micro-runtime with:
$ cmake -DWAMR_BUILD_MULTI_MODULE=1 -DWAMR_BUILD_REF_TYPES=1 -DWAMR_BUILD_FAST_JIT=1
$ make
If you manage to build a wasm shared module successfully and want to use it,
do the following:
- Add -DWAMR_BUILD_MULTI_MODULE=1 to your cmake build for wasm-micro-runtime,
- Remove the #define HB_WASM_NO_MODULES line below,
- Install your shared module with name ending in .wasm in
$(prefix)/$(libdir)/harfbuzz/wasm/
- Build your font's wasm code importing the shared modules with the desired
name. This can be done eg.: __attribute__((import_module("graphite2")))
before each symbol in the shared-module's headers.
- Try shaping your font and hope for the best...
I haven't been able to get this to work since emcc's support for shared libraries
requires support from the host that seems to be missing from wasm-micro-runtime?
|
12216 |
hb.h |
HB_H |
1555 |
hb.hh |
Unknown pragma |
18542 |
justify.py |
|
7962 |
main.cc |
_png API is so easy to use unlike the below code, don't get confused |
16856 |
meson.build |
|
33746 |
moz.build |
|
3822 |
ms-use |
|
|
OT |
|
|
relative_to.py |
|
102 |
rust |
|
|
sample.py |
|
1832 |
update-unicode-tables.make |
|
2509 |
wasm |
|
|