# Buildsheet autogenerated by ravenadm tool -- Do not edit.
NAMEBASE= python-MarkupSafe
VERSION= 3.0.2
KEYWORDS= python
VARIANTS= v12 v13
SDESC[v12]= Jinja2.Markup string implementation module (3.12)
SDESC[v13]= Jinja2.Markup string implementation module (3.13)
HOMEPAGE= none
CONTACT= Python_Automaton[python@ironwolf.systems]
DOWNLOAD_GROUPS= main
SITES[main]= PYPI/M/MarkupSafe
DISTFILE[1]= markupsafe-3.0.2.tar.gz:main
DIST_SUBDIR= python-src
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= markupsafe-3.0.2
GENERATED= yes
[PY312].USES_ON= python:v12,sutools
[PY313].USES_ON= python:v13,sutools
[FILE:1279:descriptions/desc.single]
# MarkupSafe
MarkupSafe implements a text object that escapes characters so it is
safe to use in HTML and XML. Characters that have special meanings are
replaced so that they display as the actual characters. This mitigates
injection attacks, meaning untrusted user input can safely be displayed
on a page.
## Examples
```pycon
>>> from markupsafe import Markup, escape
>>> # escape replaces special characters and wraps in Markup
>>> escape("")
Markup('<script>alert(document.cookie);</script>')
>>> # wrap in Markup to mark text "safe" and prevent escaping
>>> Markup("Hello")
Markup('hello')
>>> escape(Markup("Hello"))
Markup('hello')
>>> # Markup is a str subclass
>>> # methods and operators escape their arguments
>>> template = Markup("Hello {name}")
>>> template.format(name='"World"')
Markup('Hello "World"')
```
## Donate
The Pallets organization develops and supports MarkupSafe and other
popular packages. In order to grow the community of contributors and
users, and allow the maintainers to devote more time to the projects,
[please donate today][].
[please donate today]: https://palletsprojects.com/donate
[FILE:113:distinfo]
ee55d3edf80167e48ea11a923c7386f4669df67d7994554387f84e7d8b0a2bf0 20537 python-src/markupsafe-3.0.2.tar.gz