From 5d7f725a6a7f02b0abc98fd989e8c7b16dc9d657 Mon Sep 17 00:00:00 2001 From: Chris Brown <1731074+ccbrown@users.noreply.github.com> Date: Tue, 17 Dec 2024 20:04:14 -0500 Subject: [PATCH 1/2] test blank lines issue in ci --- packages/iocraft/src/render.rs | 145 +++++++++++++++++++++++++++++++++ 1 file changed, 145 insertions(+) diff --git a/packages/iocraft/src/render.rs b/packages/iocraft/src/render.rs index 7c98e7d..ae8a66c 100644 --- a/packages/iocraft/src/render.rs +++ b/packages/iocraft/src/render.rs @@ -559,4 +559,149 @@ mod tests { .to_string(); assert_eq!(actual, "+--------+\n+--------+\n",); } + + #[derive(Default, Props)] + pub struct ContainerProps<'a> { + pub children: Vec>, + } + + #[component] + pub fn Container<'a>( + props: &mut ContainerProps<'a>, + mut hooks: Hooks, + ) -> impl Into> { + let (width, _) = hooks.use_terminal_size(); + use std::io::Write; + write!(std::io::stdout(), "using width: {}\n", width); + + element! { + Box( + flex_direction: FlexDirection::Column, + width, + ) { + #(&mut props.children) + } + } + } + + #[test] + fn test_blank_lines_repro() { + use std::io::IsTerminal; + let is_tty = std::io::stdout().is_terminal(); + let canvas = element! { + Container { + Box( + border_color: Color::Cyan, + border_style: BorderStyle::Round, + flex_direction: FlexDirection::Column, + width: crate::Size::Auto, + ) { + Box( + border_edges: Edges::Bottom, + border_color: Color::Cyan, + border_style: BorderStyle::Round, + ) { + Box( + padding_left: 1, + width: 10pct, + ) { + Text( + content: "Plugin", + weight: Weight::Bold, + ) + } + Box( + padding_left: 1, + width: 8pct, + ) { + Text( + content: "Author", + weight: Weight::Bold, + ) + } + Box( + padding_left: 1, + width: 5pct, + ) { + Text( + content: "Format", + weight: Weight::Bold, + ) + } + Box( + padding_left: 1, + width: 20pct, + ) { + Text( + content: "Description", + weight: Weight::Bold, + ) + } + Box( + padding_left: 1, + width: 57pct, + ) { + Text( + content: "Locator", + weight: Weight::Bold, + ) + } + } + + Box { + Box( + padding_left: 1, + width: 10pct, + ) { + Text( + content: "Zig", + ) + } + Box( + padding_left: 1, + width: 8pct, + ) { + Text( + content: "stk0vrfl0w", + ) + } + Box( + padding_left: 1, + width: 5pct, + ) { + Text( + content: "TOML", + ) + } + Box( + padding_left: 1, + width: 20pct, + ) { + Text( + content: "Zig is a general-purpose programming language and toolchain.", + ) + } + Box( + padding_left: 1, + width: 57pct, + ) { + Text( + content: "https://raw.githubusercontent.com/stk0vrfl0w/proto-toml-plugins/main/plugins/zig.toml", + ) + } + } + } + } + } + .render(if is_tty { + crossterm::terminal::size().ok().map(|size| size.0 as usize) + } else { + None + }); + if is_tty { + canvas.write_ansi(std::io::stdout()).unwrap(); + } else { + canvas.write(std::io::stdout()).unwrap(); + } + } } From 29a18995c6b88082d4a108bf0d7b1c7eeac8b747 Mon Sep 17 00:00:00 2001 From: Chris Brown <1731074+ccbrown@users.noreply.github.com> Date: Tue, 17 Dec 2024 20:09:39 -0500 Subject: [PATCH 2/2] use err --- packages/iocraft/src/render.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/iocraft/src/render.rs b/packages/iocraft/src/render.rs index ae8a66c..9ced668 100644 --- a/packages/iocraft/src/render.rs +++ b/packages/iocraft/src/render.rs @@ -572,7 +572,7 @@ mod tests { ) -> impl Into> { let (width, _) = hooks.use_terminal_size(); use std::io::Write; - write!(std::io::stdout(), "using width: {}\n", width); + write!(std::io::stdout(), "using width: {}\n", width).unwrap(); element! { Box(