# Buildsheet autogenerated by ravenadm tool -- Do not edit. NAMEBASE= python-ruamel.yaml VERSION= 0.18.6 KEYWORDS= python VARIANTS= v12 v13 SDESC[v12]= YAML 1.2 parser/emitter (3.12) SDESC[v13]= YAML 1.2 parser/emitter (3.13) HOMEPAGE= none CONTACT= Python_Automaton[python@ironwolf.systems] DOWNLOAD_GROUPS= main SITES[main]= PYPIWHL/73/67/8ece580cc363331d9a53055130f86b096bf16e38156e33b1d3014fffda6b DISTFILE[1]= ruamel.yaml-0.18.6-py3-none-any.whl:main DF_INDEX= 1 SPKGS[v12]= single SPKGS[v13]= single OPTIONS_AVAILABLE= PY312 PY313 OPTIONS_STANDARD= none VOPTS[v12]= PY312=ON PY313=OFF VOPTS[v13]= PY312=OFF PY313=ON DISTNAME= ruamel.yaml-0.18.6.dist-info GENERATED= yes [PY312].RUN_DEPENDS_ON= python-ruamel.yaml.clib:single:v12 [PY312].USES_ON= python:v12,wheel [PY313].USES_ON= python:v13,wheel [FILE:3471:descriptions/desc.single] # ruamel.yaml `ruamel.yaml` is a YAML 1.2 loader/dumper package for Python.
version 0.18.6
updated 2024-02-07
documentation https://yaml.readthedocs.io
repository https://sourceforge.net/projects/ruamel-yaml
pypi https://pypi.org/project/ruamel.yaml
As announced, in 0.18.0, the old PyYAML functions have been deprecated. (`scan`, `parse`, `compose`, `load`, `emit`, `serialize`, `dump` and their variants (`_all`, `safe_`, `round_trip_`, etc)). If you only read this after your program has stopped working: I am sorry to hear that, but that also means you, or the person developing your program, has not tested with warnings on (which is the recommendation in PEP 565, and e.g. defaultin when using `pytest`). If you have troubles, explicitly use ``` pip install "ruamel.yaml<0.18.0" ``` or put something to that effects in your requirments, to give yourself some time to solve the issue. There will be at least one more potentially breaking change in the 0.18 series: `YAML(typ='unsafe')` now has a pending deprecation warning and is going to be deprecated, probably before the end of 2023. If you only use it to dump, please use the new `YAML(typ='full')`, the result of that can be *safely* loaded with a default instance `YAML()`, as that will get you inspectable, tagged, scalars, instead of executed Python functions/classes. (You should probably add constructors for what you actually need, but I do consider adding a `ruamel.yaml.unsafe` package that will re-add the `typ='unsafe'` option. *Please adjust/pin your dependencies accordingly if necessary.* There seems to be a CVE on `ruamel.yaml`, stating that the `load()` function could be abused because of unchecked input. `load()` was never the default function (that was `round_trip_load()` before the new API came into existence`. So the creator of that CVE was ill informed and probably lazily assumed that since `ruamel.yaml` is a derivative of PyYAML (for which a similar CVE exists), the same problem would still exist, without checking. So the CVE was always inappriate, now just more so, as the call to the function `load()` with any input will terminate your program with an error message. If you (have to) care about such things as this CVE, my recommendation is to stop using Python completely, as `pickle.load()` can be abused in the same way as `load()` (and like unlike `load()` is only documented to be unsafe, without development-time warning. Version 0.17.21 was the last one tested to be working on Python 3.5 and 3.6
The 0.16.13 release was the last that was tested to be working on Python 2.7. There are two extra plug-in packages (`ruamel.yaml.bytes` and `ruamel.yaml.string`) for those not wanting to do the streaming to a `io.BytesIO/StringIO` buffer themselves. If your package uses `ruamel.yaml` and is not listed on PyPI, drop me an email, preferably with some information on how you use the package (or a link to the repository) and I'll keep you informed when the status of the API is stable enough to make the transition.
    Overview

    Installing
      Optional requirements

    Basic Usage
      Load and dump  
      More examples

    Working with Python classes
      Dumping Python classes
      Dataclass


[FILE:114:distinfo]
57b53ba33def16c4f3d807c0ccbc00f8a6081827e81ba2491691b76882d0c636       117761 ruamel.yaml-0.18.6-py3-none-any.whl