const builtin = @import("builtin"); const options = @import("main.zig").options; const harfbuzz = @import("shaper/harfbuzz.zig"); pub const web_canvas = @import("shaper/web_canvas.zig"); pub usingnamespace @import("shaper/run.zig"); /// Shaper implementation for our compile options. pub const Shaper = switch (options.backend) { .freetype, .fontconfig_freetype, .coretext_freetype, .coretext, => harfbuzz.Shaper, .web_canvas => web_canvas.Shaper, }; /// A cell is a single single within a terminal that should be rendered /// for a shaping call. Note all terminal cells may be present; only /// cells that have a glyph that needs to be rendered. pub const Cell = struct { /// The column that this cell occupies. Since a set of shaper cells is /// always on the same line, only the X is stored. It is expected the /// caller has access to the original screen cell. x: u16, /// The glyph index for this cell. The font index to use alongside /// this cell is available in the text run. This glyph index is only /// valid for a given GroupCache and FontIndex that was used to create /// the runs. glyph_index: u32, };