1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-19 11:50:58 +00:00

fixup! refactor(core): safe iface for get_glyph_data

This commit is contained in:
obrusvit 2024-12-10 23:53:26 +01:00
parent cadcede0b7
commit 77b3d79e01

View File

@ -227,7 +227,12 @@ impl From<Font> for i32 {
impl Font {
/// Supports UTF8 characters
pub fn text_width(self, text: &str) -> i16 {
text.chars().fold(0, |acc, c| acc + self.char_width(c))
self.with_glyph_data(|data| {
text.chars().fold(0, |acc, c| {
let char_width = data.get_glyph(c).adv;
acc + char_width
})
})
}
/// Width of the text that is visible.
@ -350,17 +355,20 @@ impl Font {
pub fn longest_prefix(self, width: i16, text: &str) -> &str {
let mut prev_word_boundary = 0;
let mut text_width = 0;
for (i, c) in text.char_indices() {
let c_width = self.char_width(c);
if text_width + c_width > width {
// Another character would not fit => split at the previous word boundary
return &text[0..prev_word_boundary];
self.with_glyph_data(|data| {
for (i, c) in text.char_indices() {
let char_width = data.get_glyph(c).adv;
let c_width = char_width;
if text_width + c_width > width {
// Another character would not fit => split at the previous word boundary
return &text[0..prev_word_boundary];
}
if c == ' ' {
prev_word_boundary = i;
}
text_width += c_width;
}
if c == ' ' {
prev_word_boundary = i;
}
text_width += c_width;
}
});
text // the whole text fits
}
@ -369,14 +377,17 @@ impl Font {
/// that will fit into the area `width` pixels wide.
pub fn longest_suffix(self, width: i16, text: &str) -> usize {
let mut text_width = 0;
for (chars_from_right, c) in text.chars().rev().enumerate() {
let c_width = self.char_width(c);
if text_width + c_width > width {
// Another character cannot be fitted, we're done.
return chars_from_right;
self.with_glyph_data(|data| {
for (chars_from_right, c) in text.chars().rev().enumerate() {
let char_width = data.get_glyph(c).adv;
if text_width + char_width > width {
// Another character cannot be fitted, we're done.
return chars_from_right;
}
text_width += char_width;
}
text_width += c_width;
}
});
text.len() // it fits in its entirety
}