# Interface Notes --- Freetype implementation supports specifying a FT_Memory handle which is a pointer to a FT_MemoryRect. This can be used to define an allocator for the parser. Currently this library does not wrap this interface (yet). If using freetype its recommend to update `parser_init` with the necessary changes to wrap the context's backing allocator for freetype to utilize. ```c struct FT_MemoryRec_ { void* user; FT_Alloc_Func alloc; FT_Free_Func free; FT_Realloc_Func realloc; }; ``` ### startup Initializes a provided context. There are a large amount of parameters to tune the library instance to the user's preference. By default, keep in mind the library defaults to utilize stb_truetype as the font parser and harfbuzz (soon...) for the shaper. Much of the data structures within the context struct are not fixed-capacity allocations so make sure that the backing allocator utilized can handle it. ### hot_reload The library supports being used in a dynamically loaded module. If this occurs simply make sure to call this procedure with a reference to the backing allocator provided during startup as all dynamic containers tend to lose a proper reference to the allocator's procedure. ### shutdown Release resources from the context. ### configure_snap You'll find this used immediately in draw_text it acts as a way to snap the position of the text to the nearest pixel for the width and height specified. If snapping is not desired, set the snap_width and height before calling draw_text to 0. ## get_cursor_pos Will provide the current cursor_pos for the resulting text drawn. ## set_color Sets the color to utilize on `DrawCall`s for FrameBuffer.Target or .Target_Uncached passes ### get_draw_list Get the enqueded draw_list (vertices, indices, and draw call arrays) in its entirety. By default, if get_draw_list is called, it will first call `optimize_draw_list` to optimize the draw list's calls for the user. If this is undesired, make sure to pass `optimize_before_returning = false` in the arguments. ### get_draw_list_layer Get the enqueued draw_list for the current "layer". A layer is considered the slice of the drawlist's content from the last call to `flush_draw_list_layer` onward. By default, if get_draw_list_layer is called, it will first call `optimize_draw_list` for the user to optimize the slice (exlusively) of the draw list's draw calls. If this is undesired, make sure to pass `optimize_before_returning = false` in the arguments. The draw layer offsets are cleared with `flush_draw_list` ### flush_draw_list Will clear the draw list and draw layer offsets. ### flush_draw_list_layer Will update the draw list layer with the latest offset based on the current lenght of the draw list vertices, indices, and calls arrays. ### measure_text_size Provides a Vec2 the width and height occupied by the provided text string. The y is measured to be the the largest glyph box bounds height of the text. The width is derived from the `end_cursor_pos` field from a `ShapedText` entry. ## get_font_vertical_metrics A wrapper for `parser_get_font_vertical_metrics`. Will provide the ascent, descent, and line_gap for a font entry.