From 208c12a136c722e87edb16b2c31f8a8243afd89c Mon Sep 17 00:00:00 2001 From: David Moreno Date: Mon, 18 Dec 2023 21:59:27 +0100 Subject: [PATCH] Improved visualization and overflows --- cli/rtpmidid-cli.py | 20 +++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) diff --git a/cli/rtpmidid-cli.py b/cli/rtpmidid-cli.py index 3f03fb2..a0558e9 100755 --- a/cli/rtpmidid-cli.py +++ b/cli/rtpmidid-cli.py @@ -215,10 +215,12 @@ def get_latency(self, data): def print_table(self, table: list[list[str]]): def format_cell(cell, column): + width = column["width"] + cell = str(cell)[:width] if column.get("align") == "right": - return "{:>{width}}".format(cell, width=column["width"]) + return "{:>{width}}".format(cell, width=width) else: - return "{:{width}}".format(cell, width=column["width"]) + return "{:{width}}".format(cell, width=width) max_cols = self.max_cols - 1 for rown, row in enumerate(table): @@ -381,18 +383,22 @@ def print_row(self, row): data_rows = len(self.data) top_area = data_rows + 4 - max_col = self.height - top_area - 5 + max_col = self.height - top_area print(self.ANSI_BG_BLUE + self.ANSI_TEXT_WHITE, end="") self.print_padding(f"Current Row {self.height}: ") print(self.ANSI_RESET, end="") width_2 = self.width // 2 + max_col2 = max_col * 2 for idx, row in enumerate(text.split("\n")): - if idx >= max_col: - self.terminal_goto(width_2, top_area + idx - max_col) - else: + if idx >= max_col2: + continue # skip too many rows + elif idx < max_col: self.terminal_goto(0, top_area + idx) - print(row) + print(row) + else: + self.terminal_goto(width_2, top_area + idx - max_col) + print(f"| {row}") def print_data(self): data = self.conn.command({"method": "status"})