summaryrefslogtreecommitdiff
path: root/utils/src/display
diff options
context:
space:
mode:
Diffstat (limited to 'utils/src/display')
-rw-r--r--utils/src/display/str_width.rs18
-rw-r--r--utils/src/display/table.rs21
2 files changed, 20 insertions, 19 deletions
diff --git a/utils/src/display/str_width.rs b/utils/src/display/str_width.rs
new file mode 100644
index 0000000..a725bdb
--- /dev/null
+++ b/utils/src/display/str_width.rs
@@ -0,0 +1,18 @@
+pub fn display_width(s: &str) -> usize {
+ // Filter out ANSI escape sequences before calculating width
+ let filtered_bytes = strip_ansi_escapes::strip(s);
+ let filtered_str = match std::str::from_utf8(&filtered_bytes) {
+ Ok(s) => s,
+ Err(_) => s, // Fallback to original string if UTF-8 conversion fails
+ };
+
+ let mut width = 0;
+ for c in filtered_str.chars() {
+ if c.is_ascii() {
+ width += 1;
+ } else {
+ width += 2;
+ }
+ }
+ width
+}
diff --git a/utils/src/display/table.rs b/utils/src/display/table.rs
index ae745d8..e6f1aca 100644
--- a/utils/src/display/table.rs
+++ b/utils/src/display/table.rs
@@ -1,3 +1,5 @@
+use crate::display::str_width::display_width;
+
pub struct Table {
items: Vec<String>,
line: Vec<Vec<String>>,
@@ -122,22 +124,3 @@ impl std::fmt::Display for Table {
Ok(())
}
}
-
-pub fn display_width(s: &str) -> usize {
- // Filter out ANSI escape sequences before calculating width
- let filtered_bytes = strip_ansi_escapes::strip(s);
- let filtered_str = match std::str::from_utf8(&filtered_bytes) {
- Ok(s) => s,
- Err(_) => s, // Fallback to original string if UTF-8 conversion fails
- };
-
- let mut width = 0;
- for c in filtered_str.chars() {
- if c.is_ascii() {
- width += 1;
- } else {
- width += 2;
- }
- }
- width
-}