From 75b67ab999d73aa286737580e3cf1a24bede463f Mon Sep 17 00:00:00 2001 From: mecaneer23 Date: Mon, 20 May 2024 15:23:53 -0500 Subject: [PATCH] feat: add _get_delimiter_locations function --- src/md_to_py.py | 24 +++++++++++++++++++++++- 1 file changed, 23 insertions(+), 1 deletion(-) diff --git a/src/md_to_py.py b/src/md_to_py.py index 10a538d..74a4e32 100644 --- a/src/md_to_py.py +++ b/src/md_to_py.py @@ -3,7 +3,7 @@ """ from itertools import repeat -from typing import Callable, Iterable, Iterator, TypeVar +from typing import Callable, Iterable, Iterator, Sequence, TypeVar T = TypeVar("T") S = TypeVar("S") @@ -59,6 +59,28 @@ def _get_column_widths( return output[:-1] +def _get_delimiter_locations(rows: Sequence[str], delimiter: str = "|") -> Iterator[int]: + remaining_rows = len(rows) + location_number = [0 for _ in range(remaining_rows)] + column = 1 + for pos in range(len(max(rows, key=len))): + for index, row in enumerate(rows): + if pos == len(row): + remaining_rows -= 1 + continue + if pos > len(row): + continue + if row[pos] == delimiter: + location_number[index] += 1 + if all(num >= column for num in location_number): + column += 1 + yield pos + + +def _get_max_column_widths(): + raise NotImplementedError() + + def _pad_columns(row: str, widths: tuple[int, ...] | int, delimiter: str = "|") -> str: """ Pad each column (determined by `delimiter`), to a given width.