changes before ref

This commit is contained in:
Stewart Connor 2025-03-26 14:48:54 +11:00
parent 1d7850099f
commit fb852d3ab5
2 changed files with 26 additions and 23 deletions

View file

@ -5,8 +5,6 @@ use alloc::vec::Vec;
use core::ops::Range; use core::ops::Range;
use rangemap::RangeMap; use rangemap::RangeMap;
use smol_str::SmolStr; use smol_str::SmolStr;
use std::collections::HashMap;
use std::rc::Rc;
use crate::{CacheKeyFlags, Metrics}; use crate::{CacheKeyFlags, Metrics};
@ -148,6 +146,10 @@ impl FeatureTag {
pub const STYLISTIC_SET_1: Self = Self::new(b"ss01"); pub const STYLISTIC_SET_1: Self = Self::new(b"ss01");
pub const STYLISTIC_SET_2: Self = Self::new(b"ss02"); pub const STYLISTIC_SET_2: Self = Self::new(b"ss02");
// Add more common features as needed // Add more common features as needed
pub fn as_bytes(&self) -> &[u8; 4] {
&self.0
}
} }
/// Font feature with tag and value /// Font feature with tag and value
@ -194,7 +196,7 @@ impl FontFeatures {
} }
/// Text attributes /// Text attributes
#[derive(Clone, Copy, Debug, Eq, Hash, PartialEq)] #[derive(Clone, Debug, Eq, Hash, PartialEq)]
pub struct Attrs<'a> { pub struct Attrs<'a> {
//TODO: should this be an option? //TODO: should this be an option?
pub color_opt: Option<Color>, pub color_opt: Option<Color>,
@ -205,7 +207,7 @@ pub struct Attrs<'a> {
pub metadata: usize, pub metadata: usize,
pub cache_key_flags: CacheKeyFlags, pub cache_key_flags: CacheKeyFlags,
pub metrics_opt: Option<CacheMetrics>, pub metrics_opt: Option<CacheMetrics>,
pub font_features: Option<Rc<FontFeatures>>, pub font_features: Option<FontFeatures>,
} }
impl<'a> Attrs<'a> { impl<'a> Attrs<'a> {
@ -276,7 +278,7 @@ impl<'a> Attrs<'a> {
/// Set [FontFeatures] /// Set [FontFeatures]
pub fn font_features(mut self, font_features: FontFeatures) -> Self { pub fn font_features(mut self, font_features: FontFeatures) -> Self {
self.font_features = Some(Rc::new(font_features)); self.font_features = Some(font_features);
self self
} }
@ -328,7 +330,7 @@ pub struct AttrsOwned {
pub metadata: usize, pub metadata: usize,
pub cache_key_flags: CacheKeyFlags, pub cache_key_flags: CacheKeyFlags,
pub metrics_opt: Option<CacheMetrics>, pub metrics_opt: Option<CacheMetrics>,
pub font_features: Option<Rc<FontFeatures>>, pub font_features: Option<FontFeatures>,
} }
impl AttrsOwned { impl AttrsOwned {
@ -371,9 +373,9 @@ pub struct AttrsList {
impl AttrsList { impl AttrsList {
/// Create a new attributes list with a set of default [Attrs] /// Create a new attributes list with a set of default [Attrs]
pub fn new(defaults: Attrs) -> Self { pub fn new(defaults: &Attrs) -> Self {
Self { Self {
defaults: AttrsOwned::new(defaults), defaults: AttrsOwned::new(defaults.clone()),
spans: RangeMap::new(), spans: RangeMap::new(),
} }
} }
@ -399,13 +401,13 @@ impl AttrsList {
} }
/// Add an attribute span, removes any previous matching parts of spans /// Add an attribute span, removes any previous matching parts of spans
pub fn add_span(&mut self, range: Range<usize>, attrs: Attrs) { pub fn add_span(&mut self, range: Range<usize>, attrs: &Attrs) {
//do not support 1..1 or 2..1 even if by accident. //do not support 1..1 or 2..1 even if by accident.
if range.is_empty() { if range.is_empty() {
return; return;
} }
self.spans.insert(range, AttrsOwned::new(attrs)); self.spans.insert(range, AttrsOwned::new(attrs.clone()));
} }
/// Get the attribute span for an index /// Get the attribute span for an index
@ -455,8 +457,8 @@ impl AttrsList {
} }
/// Resets the attributes with new defaults. /// Resets the attributes with new defaults.
pub(crate) fn reset(mut self, default: Attrs) -> Self { pub(crate) fn reset(mut self, default: &Attrs) -> Self {
self.defaults = AttrsOwned::new(default); self.defaults = AttrsOwned::new(default.clone());
self.spans.clear(); self.spans.clear();
self self
} }

View file

@ -141,17 +141,18 @@ fn shape_fallback(
assert_eq!(rtl, span_rtl); assert_eq!(rtl, span_rtl);
let attrs = attrs_list.get_span(start_run); let attrs = attrs_list.get_span(start_run);
let mut rb_features = Vec::new();
// Convert attrs::Feature to rustybuzz::Feature // Convert attrs::Feature to rustybuzz::Feature
let font_features = attrs.get_font_features(); if let Some(font_features) = attrs.font_features {
let mut rb_features = Vec::with_capacity(font_features.features.len()); for feature in font_features.features {
for feature in &font_features.features { rb_features.push(rustybuzz::Feature::new(
rb_features.push(rustybuzz::Feature::new( rustybuzz::ttf_parser::Tag::from_bytes(&feature.tag.as_bytes()),
rustybuzz::ttf_parser::Tag::from_bytes(&feature.tag.as_bytes()), feature.value,
feature.value, 0..usize::MAX,
0..usize::MAX, ));
)); }
} };
let shape_plan = rustybuzz::ShapePlan::new( let shape_plan = rustybuzz::ShapePlan::new(
font.rustybuzz(), font.rustybuzz(),
@ -261,7 +262,7 @@ fn shape_run(
let attrs = attrs_list.get_span(start_run); let attrs = attrs_list.get_span(start_run);
let fonts = font_system.get_font_matches(attrs); let fonts = font_system.get_font_matches(&attrs);
let default_families = [&attrs.family]; let default_families = [&attrs.family];
let mut font_iter = FontFallbackIter::new( let mut font_iter = FontFallbackIter::new(
@ -444,7 +445,7 @@ fn shape_skip(
end_run: usize, end_run: usize,
) { ) {
let attrs = attrs_list.get_span(start_run); let attrs = attrs_list.get_span(start_run);
let fonts = font_system.get_font_matches(attrs); let fonts = font_system.get_font_matches(&attrs);
let default_families = [&attrs.family]; let default_families = [&attrs.family];
let mut font_iter = FontFallbackIter::new(font_system, &fonts, &default_families, &[], ""); let mut font_iter = FontFallbackIter::new(font_system, &fonts, &default_families, &[], "");