summaryrefslogtreecommitdiff
path: root/_doc/overview.ryd
blob: 43be596cca8ce5f262aa91265d1125f699273c7c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
version: 0.2
text: rst
fix_inline_single_backquotes: true
--- |
********
Overview
********

``ruamel.yaml`` is a YAML 1.2  loader/dumper package for Python. It is a
derivative of Kirill Simonov's `PyYAML 3.11
<https://bitbucket.org/xi/pyyaml>`_.

``ruamel.yaml`` supports `YAML 1.2`_ and has round-trip loaders and dumpers. 
A round-trip is a YAML load-modify-save sequence and ruamel.yaml tries to
preserve, among others:

- comments
- block style and key ordering are kept, so you can diff the round-tripped
  source
- flow style sequences ( 'a: b, c, d') (based on request and test by
  Anthony Sottile)
- anchor names that are hand-crafted (i.e. not of the form``idNNN``)
- `merges <http://yaml.org/type/merge.html>`_ in dictionaries are preserved

This preservation is normally not broken unless you severely alter
the structure of a component (delete a key in a dict, remove list entries).
Reassigning values or replacing list items, etc., is fine.

For the specific 1.2 differences see :ref:`yaml-1-2-support`

Although individual indentation of lines is not preserved, you can specify
separate indentation levels for mappings and sequences (counting for sequences
does **not** include the dash for a sequence element) and specific offset of
block sequence dashes within that indentation.


Although ``ruamel.yaml`` still allows most of the PyYAML way of doing
things, adding features required a different API then the transient
nature of PyYAML's ``Loader`` and ``Dumper``.  Starting with
``ruamel.yaml`` version 0.15.0 this new API gets introduced. Old ways
that get in the way will be removed, after first generating warnings
on use, then generating an error. In general a warning in version 0.N.x will become an
error in 0.N+1.0


Many of the bugs filed against PyYAML, but that were never
acted upon, have been fixed in ``ruamel.yaml``


--- !inc-raw |
links.rydinc