From 260009784db64ea3ba183bca0e534576925210ff Mon Sep 17 00:00:00 2001 From: KG Date: Sat, 16 Nov 2024 22:05:08 -0500 Subject: [PATCH] Add replete formatting docs --- README.md | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/README.md b/README.md index 704c17f..e624c61 100644 --- a/README.md +++ b/README.md @@ -243,6 +243,8 @@ Functions to decode and encode strings into tokens can be found in `tivars.token ## Documentation +### API + Library documentation can be found on [GitHub Pages](https://ti-toolkit.github.io/tivars_lib_py/). The var file format(s) and data sections can be found in a readable format on the [repository wiki](https://github.com/TI-Toolkit/tivars_lib_py/wiki). Much of the information is copied from the [TI-83 Link Guide](http://merthsoft.com/linkguide/ti83+/vars.html), though has been updated to account for color models. @@ -250,6 +252,25 @@ The var file format(s) and data sections can be found in a readable format on th > [!NOTE] > The wiki is still a work-in-progress. Why not [contribute a page](https://github.com/TI-Toolkit/tivars_lib_py/wiki)? +### Formatting + +All entry types support string formatting using Python's f-strings. + +- All entries support hex formatting of their data: `{sep}{width}x` + - `sep`: a single character to separate groups of hex digits *(default: none)* + - `width`: how many digits to group together *(default: no groups)* +- Tokenized entries support formatting of their tokens into readable lines: `{line_spec}{sep}{type}{lang}` + - `line_spec`: format specifier for line numbers *(default: no line numbers)* + - `sep`: a string to separate lines and line numbers *(default: none)* + - `type`: how to format each token + - `a`: use accessible names + - `d`: use display names *(default)* + - `lang`: language code of the desired translation language *(default: en)* +- Numerical entries support float-style formatting, whose complete details can be found [in the Python docs](https://docs.python.org/3/library/string.html#formatspecv). +- Lists and matrices support float-style formatting, applied to their elements. + +Additionally, the `t` type is supported for types which can be made from tokens, composing the object out of typeable (accessible) token names. For example, `-2 + 5i` is presented as `~2+5[i]`. + ## Examples You can find more sample code in `examples` that details common operations on each of the entry types. There are also examples for interfacing with popular external libraries (e.g. NumPy, PIL). Contributions welcome!