1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-19 03:40:59 +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 { impl Font {
/// Supports UTF8 characters /// Supports UTF8 characters
pub fn text_width(self, text: &str) -> i16 { 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. /// Width of the text that is visible.
@ -350,8 +355,10 @@ impl Font {
pub fn longest_prefix(self, width: i16, text: &str) -> &str { pub fn longest_prefix(self, width: i16, text: &str) -> &str {
let mut prev_word_boundary = 0; let mut prev_word_boundary = 0;
let mut text_width = 0; let mut text_width = 0;
self.with_glyph_data(|data| {
for (i, c) in text.char_indices() { for (i, c) in text.char_indices() {
let c_width = self.char_width(c); let char_width = data.get_glyph(c).adv;
let c_width = char_width;
if text_width + c_width > width { if text_width + c_width > width {
// Another character would not fit => split at the previous word boundary // Another character would not fit => split at the previous word boundary
return &text[0..prev_word_boundary]; return &text[0..prev_word_boundary];
@ -361,6 +368,7 @@ impl Font {
} }
text_width += c_width; text_width += c_width;
} }
});
text // the whole text fits text // the whole text fits
} }
@ -369,14 +377,17 @@ impl Font {
/// that will fit into the area `width` pixels wide. /// that will fit into the area `width` pixels wide.
pub fn longest_suffix(self, width: i16, text: &str) -> usize { pub fn longest_suffix(self, width: i16, text: &str) -> usize {
let mut text_width = 0; let mut text_width = 0;
self.with_glyph_data(|data| {
for (chars_from_right, c) in text.chars().rev().enumerate() { for (chars_from_right, c) in text.chars().rev().enumerate() {
let c_width = self.char_width(c); let char_width = data.get_glyph(c).adv;
if text_width + c_width > width { if text_width + char_width > width {
// Another character cannot be fitted, we're done. // Another character cannot be fitted, we're done.
return chars_from_right; return chars_from_right;
} }
text_width += c_width; text_width += char_width;
} }
});
text.len() // it fits in its entirety text.len() // it fits in its entirety
} }