1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-05 13:01:12 +00:00

chore(core/rust): use format_i64 to convert numbers to strings

This commit is contained in:
grdddj 2023-05-04 16:14:01 +02:00 committed by Martin Milata
parent 3bf3e4c38b
commit e00af4f7f3
2 changed files with 15 additions and 33 deletions

View File

@ -1,4 +1,6 @@
use crate::ui::{ use crate::{
strutil,
ui::{
component::{ component::{
base::ComponentExt, base::ComponentExt,
paginated::Paginate, paginated::Paginate,
@ -7,7 +9,7 @@ use crate::ui::{
}, },
display::{self, Font}, display::{self, Font},
geometry::{Grid, Insets, Offset, Rect}, geometry::{Grid, Insets, Offset, Rect},
util, },
}; };
use super::{theme, Button, ButtonMsg}; use super::{theme, Button, ButtonMsg};
@ -210,7 +212,7 @@ impl Component for NumberInput {
fn paint(&mut self) { fn paint(&mut self) {
let mut buf = [0u8; 10]; let mut buf = [0u8; 10];
if let Some(text) = util::u32_to_str(self.value, &mut buf) { if let Some(text) = strutil::format_i64(self.value as i64, &mut buf) {
let digit_font = Font::DEMIBOLD; let digit_font = Font::DEMIBOLD;
let y_offset = digit_font.text_height() / 2 + Button::<&str>::BASELINE_OFFSET; let y_offset = digit_font.text_height() / 2 + Button::<&str>::BASELINE_OFFSET;
display::rect_fill(self.area, theme::BG); display::rect_fill(self.area, theme::BG);

View File

@ -20,26 +20,6 @@ impl<T, E> ResultExt for Result<T, E> {
} }
} }
pub fn u32_to_str(num: u32, buffer: &mut [u8]) -> Option<&str> {
let mut i = 0;
let mut num = num;
while num > 0 && i < buffer.len() {
buffer[i] = b'0' + ((num % 10) as u8);
num /= 10;
i += 1;
}
match i {
0 => Some("0"),
_ if num > 0 => None,
_ => {
let result = &mut buffer[..i];
result.reverse();
Some(core::str::from_utf8(result).unwrap())
}
}
}
/// Constructs a string from a C string. /// Constructs a string from a C string.
/// ///
/// # Safety /// # Safety
@ -140,7 +120,7 @@ pub fn icon_text_center(
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
use super::*; use crate::strutil;
#[test] #[test]
fn u32_to_str_valid() { fn u32_to_str_valid() {
@ -148,7 +128,7 @@ mod tests {
let mut b = [0; 10]; let mut b = [0; 10];
for test in testcases { for test in testcases {
let converted = u32_to_str(test, &mut b).unwrap(); let converted = strutil::format_i64(test as i64, &mut b).unwrap();
let s = test.to_string(); let s = test.to_string();
assert_eq!(converted, s); assert_eq!(converted, s);
} }
@ -160,7 +140,7 @@ mod tests {
let mut b = [0; 3]; let mut b = [0; 3];
for test in testcases { for test in testcases {
let converted = u32_to_str(test, &mut b); let converted = strutil::format_i64(test as i64, &mut b);
assert_eq!(converted, None) assert_eq!(converted, None)
} }
} }