pub struct FcFontCache { /* private fields */ }Expand description
Font cache, initialized at startup
Implementations§
Source§impl FcFontCache
impl FcFontCache
Sourcepub fn with_memory_fonts(
&mut self,
fonts: Vec<(FcPattern, FcFont)>,
) -> &mut Self
pub fn with_memory_fonts( &mut self, fonts: Vec<(FcPattern, FcFont)>, ) -> &mut Self
Adds in-memory font files
Sourcepub fn with_memory_font_with_id(
&mut self,
id: FontId,
pattern: FcPattern,
font: FcFont,
) -> &mut Self
pub fn with_memory_font_with_id( &mut self, id: FontId, pattern: FcPattern, font: FcFont, ) -> &mut Self
Adds a memory font with a specific ID (for testing)
Sourcepub fn get_font_by_id<'a>(&'a self, id: &FontId) -> Option<FontSource<'a>>
pub fn get_font_by_id<'a>(&'a self, id: &FontId) -> Option<FontSource<'a>>
Get font data for a given font ID
Sourcepub fn get_metadata_by_id(&self, id: &FontId) -> Option<&FcPattern>
pub fn get_metadata_by_id(&self, id: &FontId) -> Option<&FcPattern>
Get metadata directly from an ID
Sourcepub fn get_font_bytes(&self, id: &FontId) -> Option<Arc<FontBytes>>
pub fn get_font_bytes(&self, id: &FontId) -> Option<Arc<FontBytes>>
Get the font bytes for id as a shared FontBytes.
On disk the returned Arc<FontBytes> wraps an mmap of the file
(FontBytes::Mmapped). Untouched pages of the file never count
toward the process’s RSS — for a font where layout shapes only
a handful of glyphs, this is the difference between paying for
the whole 4 MiB .ttc and paying for the cmap + a few glyf
pages.
In-memory fonts (FontSource::Memory) come back as
FontBytes::Owned, since the bytes are already on the heap.
Multiple FontIds backed by the same file content (every face
of a .ttc, or two paths with identical bytes) return the
same Arc<FontBytes> thanks to a content-hash → Weak
cache. Bytes get unmapped automatically when the last consumer
drops the Arc.
FontBytes derefs to [u8], so callers that only need
&[u8] (allsorts, ttf-parser, …) can pass it through without
thinking about the backing.
Failure modes: returns None if the path is unknown, or the
file no longer exists / cannot be opened, or the mmap call
fails. Callers may retry with a fresh get_font_bytes if they
suspect the file was replaced underneath them; the next call
re-opens cleanly.
Sourcepub fn is_memory_font(&self, id: &FontId) -> bool
pub fn is_memory_font(&self, id: &FontId) -> bool
Check if a font ID is a memory font (preferred over disk fonts)
Sourcepub fn query(
&self,
pattern: &FcPattern,
trace: &mut Vec<TraceMsg>,
) -> Option<FontMatch>
pub fn query( &self, pattern: &FcPattern, trace: &mut Vec<TraceMsg>, ) -> Option<FontMatch>
Queries a font from the in-memory cache, returns the first found font (early return) Memory fonts are always preferred over disk fonts with the same match quality.
Sourcepub fn compute_fallbacks(
&self,
font_id: &FontId,
trace: &mut Vec<TraceMsg>,
) -> Vec<FontMatchNoFallback>
pub fn compute_fallbacks( &self, font_id: &FontId, trace: &mut Vec<TraceMsg>, ) -> Vec<FontMatchNoFallback>
Compute fallback fonts for a given font This is a lazy operation that can be expensive - only call when actually needed (e.g., for FFI or debugging, not needed for resolve_char)
Sourcepub fn get_memory_font(&self, id: &FontId) -> Option<&FcFont>
pub fn get_memory_font(&self, id: &FontId) -> Option<&FcFont>
Get in-memory font data
pub fn query_matches_internal( k: &FcPattern, pattern: &FcPattern, trace: &mut Vec<TraceMsg>, ) -> bool
Sourcepub fn resolve_font_chain(
&self,
font_families: &[String],
weight: FcWeight,
italic: PatternMatch,
oblique: PatternMatch,
trace: &mut Vec<TraceMsg>,
) -> FontFallbackChain
pub fn resolve_font_chain( &self, font_families: &[String], weight: FcWeight, italic: PatternMatch, oblique: PatternMatch, trace: &mut Vec<TraceMsg>, ) -> FontFallbackChain
Resolve a complete font fallback chain for a CSS font-family stack This is the main entry point for font resolution with caching Automatically expands generic CSS families (serif, sans-serif, monospace) to OS-specific fonts
§Arguments
font_families- CSS font-family stack (e.g., [“Arial”, “sans-serif”])text- The text to render (used to extract Unicode ranges)weight- Font weightitalic- Italic style requirementoblique- Oblique style requirementtrace- Debug trace messages
§Returns
A complete font fallback chain with CSS fallbacks and Unicode fallbacks
§Example
let cache = FcFontCache::build();
let families = vec!["Arial".to_string(), "sans-serif".to_string()];
let chain = cache.resolve_font_chain(&families, FcWeight::Normal,
PatternMatch::DontCare, PatternMatch::DontCare,
&mut Vec::new());
// On macOS: families expanded to ["Arial", "San Francisco", "Helvetica Neue", "Lucida Grande"]Sourcepub fn resolve_font_chain_with_os(
&self,
font_families: &[String],
weight: FcWeight,
italic: PatternMatch,
oblique: PatternMatch,
trace: &mut Vec<TraceMsg>,
os: OperatingSystem,
) -> FontFallbackChain
pub fn resolve_font_chain_with_os( &self, font_families: &[String], weight: FcWeight, italic: PatternMatch, oblique: PatternMatch, trace: &mut Vec<TraceMsg>, os: OperatingSystem, ) -> FontFallbackChain
Resolve font chain with explicit OS specification (useful for testing)
Sourcepub fn resolve_font_chain_with_scripts(
&self,
font_families: &[String],
weight: FcWeight,
italic: PatternMatch,
oblique: PatternMatch,
scripts_hint: Option<&[UnicodeRange]>,
trace: &mut Vec<TraceMsg>,
) -> FontFallbackChain
pub fn resolve_font_chain_with_scripts( &self, font_families: &[String], weight: FcWeight, italic: PatternMatch, oblique: PatternMatch, scripts_hint: Option<&[UnicodeRange]>, trace: &mut Vec<TraceMsg>, ) -> FontFallbackChain
Resolve a font fallback chain, restricting Unicode fallbacks to the caller-supplied set of scripts (usually derived from the actual text content of the document).
scripts_hint: None→ back-compat behaviour, equivalent toFcFontCache::resolve_font_chain: pulls in fallback fonts for the fullDEFAULT_UNICODE_FALLBACK_SCRIPTSset.scripts_hint: Some(&[])→ no Unicode fallbacks attached. For an ASCII-only page this avoids pulling Arial Unicode MS, CJK fonts, etc. into memory when they’re not needed.scripts_hint: Some(&[CJK])→ only CJK fallback attached.
The chain cache is keyed so an ASCII-only resolution cannot be served from a slot populated by a default/all-scripts resolution.
Sourcepub fn extract_font_name_tokens(name: &str) -> Vec<String>
pub fn extract_font_name_tokens(name: &str) -> Vec<String>
Extract tokens from a font name E.g., “NotoSansJP” -> [“Noto”, “Sans”, “JP”] E.g., “Noto Sans CJK JP” -> [“Noto”, “Sans”, “CJK”, “JP”]
Sourcepub fn calculate_unicode_coverage(ranges: &[UnicodeRange]) -> u64
pub fn calculate_unicode_coverage(ranges: &[UnicodeRange]) -> u64
Find fallback fonts for a given pattern
Sourcepub fn calculate_unicode_compatibility(
requested: &[UnicodeRange],
available: &[UnicodeRange],
) -> i32
pub fn calculate_unicode_compatibility( requested: &[UnicodeRange], available: &[UnicodeRange], ) -> i32
Calculate how well a font’s Unicode ranges cover the requested ranges Returns a compatibility score (higher is better, 0 means no overlap)