X-Git-Url: https://wannabe.guru.org/gitweb/?a=blobdiff_plain;ds=inline;f=text_utils.py;h=bc05dd9cd791636e8d8ff0a90e9444817ce33af3;hb=fc113e1f62876278f5a181a86f9773c62e63a395;hp=36cfe2fd720d9e0cb479992495a70d66161ae132;hpb=eb9e6df32ed696158bf34dba6464277b648f5c74;p=python_utils.git diff --git a/text_utils.py b/text_utils.py index 36cfe2f..bc05dd9 100644 --- a/text_utils.py +++ b/text_utils.py @@ -3,6 +3,7 @@ """Utilities for dealing with "text".""" from collections import defaultdict +import logging import math import sys from typing import List, NamedTuple, Optional @@ -10,6 +11,9 @@ from typing import List, NamedTuple, Optional from ansi import fg, reset +logger = logging.getLogger(__file__) + + class RowsColumns(NamedTuple): rows: int columns: int @@ -18,8 +22,15 @@ class RowsColumns(NamedTuple): def get_console_rows_columns() -> RowsColumns: """Returns the number of rows/columns on the current console.""" - from exec_utils import cmd - rows, columns = cmd("stty size").split() + from exec_utils import cmd_with_timeout + try: + rows, columns = cmd_with_timeout( + "stty size", + timeout_seconds=1.0, + ).split() + except Exception as e: + logger.exception(e) + raise Exception('Can\'t determine console size?!') return RowsColumns(int(rows), int(columns)) @@ -117,6 +128,10 @@ def distribute_strings( string, width=subwidth, alignment=alignment, padding=padding ) retval += string + while(len(retval) > width): + retval = retval.replace(' ', ' ', 1) + while(len(retval) < width): + retval = retval.replace(' ', ' ', 1) return retval @@ -135,13 +150,8 @@ def justify_string_by_chunk( padding = padding[0] first, *rest, last = string.split() w = width - (len(first) + 1 + len(last) + 1) - retval = ( - first + padding + distribute_strings(rest, width=w, padding=padding) - ) - while len(retval) + len(last) < width: - retval += padding - retval += last - return retval + ret = first + padding + distribute_strings(rest, width=w, padding=padding) + padding + last + return ret def justify_string(