X-Git-Url: http://git.scottworley.com/rfc1751/blobdiff_plain/433a7490d1d253e49e1607c26bff94ff904080cd..812ca2069a573d8abf45a3835f41a8838e5052ea:/rfc1751.py diff --git a/rfc1751.py b/rfc1751.py index f855d9f..70f5b3a 100644 --- a/rfc1751.py +++ b/rfc1751.py @@ -18,20 +18,31 @@ import sys from rfc1751wordlist import WORD_LIST, WORD_LIST_SIZE -# TODO: Decode +WORD_LIST_INVERTED = {word: i for (i, word) in enumerate(WORD_LIST)} +assert len(WORD_LIST_INVERTED) == WORD_LIST_SIZE -def rfc1751_actual(x: int) -> list[str]: - return [] if x <= 0 else rfc1751_actual( +def encode_actual(x: int) -> list[str]: + return [] if x <= 0 else encode_actual( x // WORD_LIST_SIZE) + [WORD_LIST[x % WORD_LIST_SIZE]] -def rfc1751(x: int) -> list[str]: - return [WORD_LIST[x]] if x == 0 else rfc1751_actual(x) +def encode(x: int) -> list[str]: + return [WORD_LIST[x]] if x == 0 else encode_actual(x) + + +def decode(x: list[str]) -> int: + return WORD_LIST_SIZE * decode(x[:-1]) + \ + WORD_LIST_INVERTED[x[-1]] if x else 0 def main() -> None: - print(' '.join(rfc1751(int(sys.argv[1])))) + if sys.argv[1].isnumeric(): + print(' '.join(encode(int(sys.argv[1])))) + elif len(sys.argv) == 2: + print(decode(sys.argv[1].split(' '))) + else: + print(decode(sys.argv[1:])) if __name__ == '__main__':