preserves/implementations/python/docs/index.md

31 lines
1.3 KiB
Markdown
Raw Normal View History

# Overview
This package implements [Preserves](https://preserves.dev/) for Python 3.x. It provides the
core [semantics][] as well as both the [human-readable text
syntax](https://preserves.dev/preserves-text.html) (a superset of JSON) and [machine-oriented
binary format](https://preserves.dev/preserves-binary.html) (including canonicalization) for
Preserves. It also implements [Preserves Schema](https://preserves.dev/preserves-schema.html)
and [Preserves Path](https://preserves.dev/preserves-path.html).
- Main package API: [preserves](/api)
## What is Preserves?
{% include "what-is-preserves.md" %}
## Mapping between Preserves values and Python values
Preserves `Value`s are categorized in the following way:
{% include "value-grammar.md" %}
Python's strings, byte strings, integers, booleans, and double-precision floats stand directly
for their Preserves counterparts. Small wrapper classes for `Float` and `Symbol` complete the
suite of atomic types.
Python's lists and tuples correspond to Preserves `Sequence`s, and dicts and sets to
`Dictionary` and `Set` values, respectively. Preserves `Record`s are represented by a `Record`
class. Finally, embedded values are represented by a small `Embedded` wrapper class.
[semantics]: https://preserves.dev/preserves.html#semantics