1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-25 14:50:57 +00:00

chore(core/rust): Rename Text to FormattedText

This commit is contained in:
Jan Pochyla 2021-11-18 21:35:10 +01:00 committed by matejcik
parent 39263144b7
commit d5a74a8614
3 changed files with 28 additions and 49 deletions

View File

@ -8,4 +8,4 @@ pub mod tuple;
pub use base::{Child, Component, Event, EventCtx, Never, TimerToken}; pub use base::{Child, Component, Event, EventCtx, Never, TimerToken};
pub use empty::Empty; pub use empty::Empty;
pub use label::{Label, LabelStyle}; pub use label::{Label, LabelStyle};
pub use text::{LineBreaking, PageBreaking, Text, TextLayout}; pub use text::{FormattedText, LineBreaking, PageBreaking, TextLayout};

View File

@ -14,13 +14,13 @@ use crate::ui::{
pub const MAX_ARGUMENTS: usize = 6; pub const MAX_ARGUMENTS: usize = 6;
pub struct Text<F, T> { pub struct FormattedText<F, T> {
layout: TextLayout, layout: TextLayout,
format: F, format: F,
args: LinearMap<&'static [u8], T, MAX_ARGUMENTS>, args: LinearMap<&'static [u8], T, MAX_ARGUMENTS>,
} }
impl<F, T> Text<F, T> { impl<F, T> FormattedText<F, T> {
pub fn new<D: DefaultTextTheme>(area: Rect, format: F) -> Self { pub fn new<D: DefaultTextTheme>(area: Rect, format: F) -> Self {
Self { Self {
layout: TextLayout::new::<D>(area), layout: TextLayout::new::<D>(area),
@ -29,11 +29,6 @@ impl<F, T> Text<F, T> {
} }
} }
pub fn format(mut self, format: F) -> Self {
self.format = format;
self
}
pub fn with(mut self, key: &'static [u8], value: T) -> Self { pub fn with(mut self, key: &'static [u8], value: T) -> Self {
if self.args.insert(key, value).is_err() { if self.args.insert(key, value).is_err() {
// Map is full, ignore. // Map is full, ignore.
@ -43,6 +38,11 @@ impl<F, T> Text<F, T> {
self self
} }
pub fn with_format(mut self, format: F) -> Self {
self.format = format;
self
}
pub fn with_text_font(mut self, text_font: Font) -> Self { pub fn with_text_font(mut self, text_font: Font) -> Self {
self.layout.text_font = text_font; self.layout.text_font = text_font;
self self
@ -68,15 +68,14 @@ impl<F, T> Text<F, T> {
} }
} }
impl<F, T> Text<F, T> impl<F, T> FormattedText<F, T>
where where
F: AsRef<[u8]>, F: AsRef<[u8]>,
T: AsRef<[u8]>, T: AsRef<[u8]>,
{ {
fn layout_content(&self, sink: &mut dyn LayoutSink) { fn layout_content(&self, sink: &mut dyn LayoutSink) {
self.layout.layout_formatted( let mut cursor = self.layout.initial_cursor();
self.format.as_ref(), let mut ops = Tokenizer::new(self.format.as_ref()).flat_map(|arg| match arg {
|arg| match arg {
Token::Literal(literal) => Some(Op::Text(literal)), Token::Literal(literal) => Some(Op::Text(literal)),
Token::Argument(b"mono") => Some(Op::Font(self.layout.mono_font)), Token::Argument(b"mono") => Some(Op::Font(self.layout.mono_font)),
Token::Argument(b"bold") => Some(Op::Font(self.layout.bold_font)), Token::Argument(b"bold") => Some(Op::Font(self.layout.bold_font)),
@ -85,13 +84,12 @@ where
.args .args
.get(argument) .get(argument)
.map(|value| Op::Text(value.as_ref())), .map(|value| Op::Text(value.as_ref())),
}, });
sink, self.layout.layout_ops(&mut ops, &mut cursor, sink);
);
} }
} }
impl<F, T> Component for Text<F, T> impl<F, T> Component for FormattedText<F, T>
where where
F: AsRef<[u8]>, F: AsRef<[u8]>,
T: AsRef<[u8]>, T: AsRef<[u8]>,
@ -131,7 +129,7 @@ mod trace {
} }
} }
pub struct TraceText<'a, F, T>(pub &'a Text<F, T>); pub struct TraceText<'a, F, T>(pub &'a FormattedText<F, T>);
impl<'a, F, T> crate::trace::Trace for TraceText<'a, F, T> impl<'a, F, T> crate::trace::Trace for TraceText<'a, F, T>
where where
@ -145,7 +143,7 @@ mod trace {
} }
#[cfg(feature = "ui_debug")] #[cfg(feature = "ui_debug")]
impl<F, T> crate::trace::Trace for Text<F, T> impl<F, T> crate::trace::Trace for FormattedText<F, T>
where where
F: AsRef<[u8]>, F: AsRef<[u8]>,
T: AsRef<[u8]>, T: AsRef<[u8]>,
@ -250,26 +248,7 @@ impl TextLayout {
) )
} }
pub fn layout_formatted<'f, 'o, F, I>( pub fn layout_ops<'o>(
self,
format: &'f [u8],
resolve: F,
sink: &mut dyn LayoutSink,
) -> LayoutFit
where
F: Fn(Token<'f>) -> I,
I: IntoIterator<Item = Op<'o>>,
{
let mut cursor = self.initial_cursor();
self.layout_op_stream(
&mut Tokenizer::new(format).flat_map(resolve),
&mut cursor,
sink,
)
}
pub fn layout_op_stream<'o>(
mut self, mut self,
ops: &mut dyn Iterator<Item = Op<'o>>, ops: &mut dyn Iterator<Item = Op<'o>>,
cursor: &mut Point, cursor: &mut Point,

View File

@ -4,7 +4,7 @@ use crate::{
error::Error, error::Error,
micropython::{buffer::Buffer, obj::Obj}, micropython::{buffer::Buffer, obj::Obj},
ui::{ ui::{
component::{Child, Text}, component::{Child, FormattedText},
display, display,
layout::obj::LayoutObj, layout::obj::LayoutObj,
}, },
@ -40,7 +40,7 @@ extern "C" fn ui_layout_new_example(param: Obj) -> Obj {
let layout = LayoutObj::new(Child::new(Dialog::new( let layout = LayoutObj::new(Child::new(Dialog::new(
display::screen(), display::screen(),
|area| { |area| {
Text::new::<theme::TTDefaultText>(area, param) FormattedText::new::<theme::TTDefaultText>(area, param)
.with(b"some", "a few") .with(b"some", "a few")
.with(b"param", "xx") .with(b"param", "xx")
}, },
@ -100,7 +100,7 @@ mod tests {
let layout = Child::new(Dialog::new( let layout = Child::new(Dialog::new(
display::screen(), display::screen(),
|area| { |area| {
Text::new::<theme::TTDefaultText>( FormattedText::new::<theme::TTDefaultText>(
area, area,
"Testing text layout, with some text, and some more text. And {param}", "Testing text layout, with some text, and some more text. And {param}",
) )