mirror of
https://github.com/ghostty-org/ghostty.git
synced 2025-07-25 13:16:11 +03:00
33 lines
1.2 KiB
Zig
33 lines
1.2 KiB
Zig
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,
|
|
};
|