]> git.scottworley.com Git - rfc1751/blame_incremental - rfc1751.py
decode support
[rfc1751] / rfc1751.py
... / ...
CommitLineData
1# Copyright (c) 2024 Scott Worley <scottworley@scottworley.com>
2#
3# Permission to use, copy, modify, and distribute this software for any
4# purpose with or without fee is hereby granted, provided that the above
5# copyright notice and this permission notice appear in all copies.
6#
7# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
8# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
9# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
10# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
11# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
12# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
13# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
14
15
16import sys
17
18from rfc1751wordlist import WORD_LIST, WORD_LIST_SIZE
19
20
21WORD_LIST_INVERTED = {word: i for (i, word) in enumerate(WORD_LIST)}
22assert len(WORD_LIST_INVERTED) == WORD_LIST_SIZE
23
24
25def encode_actual(x: int) -> list[str]:
26 return [] if x <= 0 else encode_actual(
27 x // WORD_LIST_SIZE) + [WORD_LIST[x % WORD_LIST_SIZE]]
28
29
30def encode(x: int) -> list[str]:
31 return [WORD_LIST[x]] if x == 0 else encode_actual(x)
32
33
34def decode(x: list[str]) -> int:
35 return WORD_LIST_SIZE * decode(x[:-1]) + \
36 WORD_LIST_INVERTED[x[-1]] if x else 0
37
38
39def main() -> None:
40 if sys.argv[1].isnumeric():
41 print(' '.join(encode(int(sys.argv[1]))))
42 elif len(sys.argv) == 2:
43 print(decode(sys.argv[1].split(' ')))
44 else:
45 print(decode(sys.argv[1:]))
46
47
48if __name__ == '__main__':
49 main()