Changelog
### 5.1.0
```
==================
Features added
--------------
* Parsing ASCII strings is slightly faster.
Bugs fixed
----------
* GH349: The HTML ``Cleaner()`` interpreted an accidentally provided string parameter
for the ``host_whitelist`` as list of characters and silently failed to reject any hosts.
Passing a non-collection is now rejected.
Other changes
-------------
* Support for Python 2.7 and Python versions < 3.6 was removed.
* The wheel build was migrated to use ``cibuildwheel``.
Patch by Primož Godec.
```
### 5.0.1
```
==================
Bugs fixed
----------
* LP2046208: Parsing non-BMP Python Unicode strings could fail on macOS.
* LP2044225: When incrementally parsing broken HTML, reporting start events on
missing structural tags failed and could lead to subsequent exceptions.
* LP2045435: Some (not all) issues with stricter C compilers were resolved.
* The binary wheels in the 5.0.0 release did not validate cleanly (but installed ok).
.. _latest_release:
```
### 5.0.0
```
==================
Features added
--------------
* Character escaping in ``C14N2`` serialisation now uses a single pass over the text
instead of searching for each unescaped character separately.
* Early support for Python 3.13a2 was added.
Bugs fixed
----------
* LP1976304: The ``Element.addnext()`` method previously inserted the new element
before existing tail text. The tail text of both sibling elements now stays on
the respective elements.
* LP1980767, GH379: ``TreeBuilder.close()`` could fail with a ``TypeError`` after
parsing incorrect input. Original patch by Enrico Minack.
* ``Element.itertext(with_tail=False)`` returned the tail text of comments and
processing instructions, despite the explicit option.
* GH370: A crash with recent libxml2 2.11.x versions was resolved.
Patch by Michael Schlenker.
* A compile problem with recent libxml2 2.12.x versions was resolved.
* The internal exception handling in C callbacks was improved for Cython 3.0.
* The exception declarations of ``xmlInputReadCallback``, ``xmlInputCloseCallback``,
``xmlOutputWriteCallback`` and ``xmlOutputCloseCallback`` in ``tree.pxd`` were
corrected to prevent running Python code or calling into the C-API with a live
exception set.
* GH385: The long deprecated ``unittest.m̀akeSuite()`` function is no longer used.
Patch by Miro Hrončok.
* LP1522052: A file-system specific test is now optional and should no longer fail
on systems that don't support it.
* GH392: Some tests were adapted for libxml2 2.13.
Patch by Nick Wellnhofer.
* Contains all fixes from lxml 4.9.4.
Other changes
-------------
* LP1742885: lxml no longer expands external entities (XXE) by default to prevent
the security risk of loading arbitrary files and URLs. If this feature is needed,
it can be enabled in a backwards compatible way by using a parser with the option
``resolve_entities=True``. The new default is ``resolve_entities='internal'``.
* With libxml2 2.10.4 and later (as provided by the lxml 5.0 binary wheels),
parsing HTML tags with "prefixes" no longer builds a namespace dictionary
in ``nsmap`` but considers the ``prefix:name`` string the actual tag name.
With older libxml2 versions, since 2.9.11, the prefix was removed. Before
that, the prefix was parsed as XML prefix.
lxml 5.0 does not try to hide this difference but now changes the ElementPath
implementation to let ``element.find("part1:part2")`` search for the tag
``part1:part2`` in documents parsed as HTML, instead of looking only for ``part2``.
* LP2024343: The validation of the schema file itself is now optional in the
ISO-Schematron implementation. This was done because some lxml distributions
discard the RNG validation schema file due to licensing issues. The validation
can now always be disabled with ``Schematron(..., validate_schema=False)``.
It is enabled by default if available and disabled otherwise. The module
constant ``lxml.isoschematron.schematron_schema_valid_supported`` can be used
to detect whether schema file validation is available.
* Some redundant and long deprecated methods were removed:
``parser.setElementClassLookup()``,
``xslt_transform.apply()``,
``xpath.evaluate()``.
* Some incorrect declarations were removed from ``python.pxd``. In general, this file
should not be used by external Cython code. Use the C-API declarations provided by
Cython itself instead.
* Binary wheels use the library versions libxml2 2.12.3 and libxslt 1.1.39.
* Built with Cython 3.0.7, updated to follow recent changes in Cython 3.1-dev.
```
### 4.9.4
```
==================
Bugs fixed
----------
* LP2046398: Inserting/replacing an ancestor into a node's children could loop indefinitely.
* LP1980767, GH379: ``TreeBuilder.close()`` could fail with a ``TypeError`` after
parsing incorrect input. Original patch by Enrico Minack.
* LP1522052: A file-system specific test is now optional and should no longer fail
on systems that don't support it.
Other changes
-------------
* Wheels include zlib 1.3, libxml2 2.10.3 and libxslt 1.1.39
(zlib 1.2.12, libxml2 2.10.3 and libxslt 1.1.37 on Windows).
* Built with Cython 0.29.37.
```
### 4.9.3
```
==================
Bugs fixed
----------
* LP2008911: ``lxml.objectify`` accepted non-decimal numbers like ``²²²`` as integers.
* A memory leak in ``lxml.html.clean`` was resolved by switching to Cython 0.29.34+.
* GH348: URL checking in the HTML cleaner was improved.
Patch by Tim McCormack.
* GH371, GH373: Some regex strings were changed to raw strings to fix Python warnings.
Patches by Jakub Wilk and Anthony Sottile.
Other changes
-------------
* Wheels include zlib 1.2.13, libxml2 2.10.3 and libxslt 1.1.38
(zlib 1.2.12, libxml2 2.10.3 and libxslt 1.1.37 on Windows).
* Built with Cython 0.29.36 to adapt to changes in Python 3.12.
```
### 4.9.2
```
==================
Bugs fixed
----------
* CVE-2022-2309: A Bug in libxml2 2.9.1[0-4] could let namespace declarations
from a failed parser run leak into later parser runs. This bug was worked around
in lxml and resolved in libxml2 2.10.0.
https://gitlab.gnome.org/GNOME/libxml2/-/issues/378
Other changes
-------------
* LP1981760: ``Element.attrib`` now registers as ``collections.abc.MutableMapping``.
* lxml now has a static build setup for macOS on ARM64 machines (not used for building wheels).
Patch by Quentin Leffray.
```
### 4.9.1
```
==================
Bugs fixed
----------
* A crash was resolved when using ``iterwalk()`` (or ``canonicalize()``)
after parsing certain incorrect input. Note that ``iterwalk()`` can crash
on *valid* input parsed with the same parser *after* failing to parse the
incorrect input.
```
### 4.9.0
```
==================
Bugs fixed
----------
* GH341: The mixin inheritance order in ``lxml.html`` was corrected.
Patch by xmo-odoo.
Other changes
-------------
* Built with Cython 0.29.30 to adapt to changes in Python 3.11 and 3.12.
* Wheels include zlib 1.2.12, libxml2 2.9.14 and libxslt 1.1.35
(libxml2 2.9.12+ and libxslt 1.1.34 on Windows).
* GH343: Windows-AArch64 build support in Visual Studio.
Patch by Steve Dower.
```
### 4.8.0
```
==================
Features added
--------------
* GH337: Path-like objects are now supported throughout the API instead of just strings.
Patch by Henning Janssen.
* The ``ElementMaker`` now supports ``QName`` values as tags, which always override
the default namespace of the factory.
Bugs fixed
----------
* GH338: In lxml.objectify, the XSI float annotation "nan" and "inf" were spelled in
lower case, whereas XML Schema datatypes define them as "NaN" and "INF" respectively.
Patch by Tobias Deiminger.
Other changes
-------------
* Built with Cython 0.29.28.
```
### 4.7.1
```
==================
Features added
--------------
* Chunked Unicode string parsing via ``parser.feed()`` now encodes the input data
to the native UTF-8 encoding directly, instead of going through ``Py_UNICODE`` /
``wchar_t`` encoding first, which previously required duplicate recoding in most cases.
Bugs fixed
----------
* The standard namespace prefixes were mishandled during "C14N2" serialisation on Python 3.
See https://mail.python.org/archives/list/lxmlpython.org/thread/6ZFBHFOVHOS5GFDOAMPCT6HM5HZPWQ4Q/
* ``lxml.objectify`` previously accepted non-XML numbers with underscores (like "1_000")
as integers or float values in Python 3.6 and later. It now adheres to the number
format of the XML spec again.
* LP1939031: Static wheels of lxml now contain the header files of zlib and libiconv
(in addition to the already provided headers of libxml2/libxslt/libexslt).
Other changes
-------------
* Wheels include libxml2 2.9.12+ and libxslt 1.1.34 (also on Windows).
```
### 4.7.0
```
==================
* Release retracted due to missing files in lxml/includes/.
```
### 4.6.5
```
==================
Bugs fixed
----------
* A vulnerability (GHSL-2021-1038) in the HTML cleaner allowed sneaking script
content through SVG images (CVE-2021-43818).
* A vulnerability (GHSL-2021-1037) in the HTML cleaner allowed sneaking script
content through CSS imports and other crafted constructs (CVE-2021-43818).
```
### 4.6.4
```
==================
Features added
--------------
* GH317: A new property ``system_url`` was added to DTD entities.
Patch by Thirdegree.
* GH314: The ``STATIC_*`` variables in ``setup.py`` can now be passed via env vars.
Patch by Isaac Jurado.
```
Links
- PyPI: https://pypi.org/project/lxml
- Changelog: https://data.safetycli.com/changelogs/lxml/
- Homepage: https://lxml.de/
This PR updates lxml from 4.6.3 to 5.1.0.
Changelog
### 5.1.0 ``` ================== Features added -------------- * Parsing ASCII strings is slightly faster. Bugs fixed ---------- * GH349: The HTML ``Cleaner()`` interpreted an accidentally provided string parameter for the ``host_whitelist`` as list of characters and silently failed to reject any hosts. Passing a non-collection is now rejected. Other changes ------------- * Support for Python 2.7 and Python versions < 3.6 was removed. * The wheel build was migrated to use ``cibuildwheel``. Patch by Primož Godec. ``` ### 5.0.1 ``` ================== Bugs fixed ---------- * LP2046208: Parsing non-BMP Python Unicode strings could fail on macOS. * LP2044225: When incrementally parsing broken HTML, reporting start events on missing structural tags failed and could lead to subsequent exceptions. * LP2045435: Some (not all) issues with stricter C compilers were resolved. * The binary wheels in the 5.0.0 release did not validate cleanly (but installed ok). .. _latest_release: ``` ### 5.0.0 ``` ================== Features added -------------- * Character escaping in ``C14N2`` serialisation now uses a single pass over the text instead of searching for each unescaped character separately. * Early support for Python 3.13a2 was added. Bugs fixed ---------- * LP1976304: The ``Element.addnext()`` method previously inserted the new element before existing tail text. The tail text of both sibling elements now stays on the respective elements. * LP1980767, GH379: ``TreeBuilder.close()`` could fail with a ``TypeError`` after parsing incorrect input. Original patch by Enrico Minack. * ``Element.itertext(with_tail=False)`` returned the tail text of comments and processing instructions, despite the explicit option. * GH370: A crash with recent libxml2 2.11.x versions was resolved. Patch by Michael Schlenker. * A compile problem with recent libxml2 2.12.x versions was resolved. * The internal exception handling in C callbacks was improved for Cython 3.0. * The exception declarations of ``xmlInputReadCallback``, ``xmlInputCloseCallback``, ``xmlOutputWriteCallback`` and ``xmlOutputCloseCallback`` in ``tree.pxd`` were corrected to prevent running Python code or calling into the C-API with a live exception set. * GH385: The long deprecated ``unittest.m̀akeSuite()`` function is no longer used. Patch by Miro Hrončok. * LP1522052: A file-system specific test is now optional and should no longer fail on systems that don't support it. * GH392: Some tests were adapted for libxml2 2.13. Patch by Nick Wellnhofer. * Contains all fixes from lxml 4.9.4. Other changes ------------- * LP1742885: lxml no longer expands external entities (XXE) by default to prevent the security risk of loading arbitrary files and URLs. If this feature is needed, it can be enabled in a backwards compatible way by using a parser with the option ``resolve_entities=True``. The new default is ``resolve_entities='internal'``. * With libxml2 2.10.4 and later (as provided by the lxml 5.0 binary wheels), parsing HTML tags with "prefixes" no longer builds a namespace dictionary in ``nsmap`` but considers the ``prefix:name`` string the actual tag name. With older libxml2 versions, since 2.9.11, the prefix was removed. Before that, the prefix was parsed as XML prefix. lxml 5.0 does not try to hide this difference but now changes the ElementPath implementation to let ``element.find("part1:part2")`` search for the tag ``part1:part2`` in documents parsed as HTML, instead of looking only for ``part2``. * LP2024343: The validation of the schema file itself is now optional in the ISO-Schematron implementation. This was done because some lxml distributions discard the RNG validation schema file due to licensing issues. The validation can now always be disabled with ``Schematron(..., validate_schema=False)``. It is enabled by default if available and disabled otherwise. The module constant ``lxml.isoschematron.schematron_schema_valid_supported`` can be used to detect whether schema file validation is available. * Some redundant and long deprecated methods were removed: ``parser.setElementClassLookup()``, ``xslt_transform.apply()``, ``xpath.evaluate()``. * Some incorrect declarations were removed from ``python.pxd``. In general, this file should not be used by external Cython code. Use the C-API declarations provided by Cython itself instead. * Binary wheels use the library versions libxml2 2.12.3 and libxslt 1.1.39. * Built with Cython 3.0.7, updated to follow recent changes in Cython 3.1-dev. ``` ### 4.9.4 ``` ================== Bugs fixed ---------- * LP2046398: Inserting/replacing an ancestor into a node's children could loop indefinitely. * LP1980767, GH379: ``TreeBuilder.close()`` could fail with a ``TypeError`` after parsing incorrect input. Original patch by Enrico Minack. * LP1522052: A file-system specific test is now optional and should no longer fail on systems that don't support it. Other changes ------------- * Wheels include zlib 1.3, libxml2 2.10.3 and libxslt 1.1.39 (zlib 1.2.12, libxml2 2.10.3 and libxslt 1.1.37 on Windows). * Built with Cython 0.29.37. ``` ### 4.9.3 ``` ================== Bugs fixed ---------- * LP2008911: ``lxml.objectify`` accepted non-decimal numbers like ``²²²`` as integers. * A memory leak in ``lxml.html.clean`` was resolved by switching to Cython 0.29.34+. * GH348: URL checking in the HTML cleaner was improved. Patch by Tim McCormack. * GH371, GH373: Some regex strings were changed to raw strings to fix Python warnings. Patches by Jakub Wilk and Anthony Sottile. Other changes ------------- * Wheels include zlib 1.2.13, libxml2 2.10.3 and libxslt 1.1.38 (zlib 1.2.12, libxml2 2.10.3 and libxslt 1.1.37 on Windows). * Built with Cython 0.29.36 to adapt to changes in Python 3.12. ``` ### 4.9.2 ``` ================== Bugs fixed ---------- * CVE-2022-2309: A Bug in libxml2 2.9.1[0-4] could let namespace declarations from a failed parser run leak into later parser runs. This bug was worked around in lxml and resolved in libxml2 2.10.0. https://gitlab.gnome.org/GNOME/libxml2/-/issues/378 Other changes ------------- * LP1981760: ``Element.attrib`` now registers as ``collections.abc.MutableMapping``. * lxml now has a static build setup for macOS on ARM64 machines (not used for building wheels). Patch by Quentin Leffray. ``` ### 4.9.1 ``` ================== Bugs fixed ---------- * A crash was resolved when using ``iterwalk()`` (or ``canonicalize()``) after parsing certain incorrect input. Note that ``iterwalk()`` can crash on *valid* input parsed with the same parser *after* failing to parse the incorrect input. ``` ### 4.9.0 ``` ================== Bugs fixed ---------- * GH341: The mixin inheritance order in ``lxml.html`` was corrected. Patch by xmo-odoo. Other changes ------------- * Built with Cython 0.29.30 to adapt to changes in Python 3.11 and 3.12. * Wheels include zlib 1.2.12, libxml2 2.9.14 and libxslt 1.1.35 (libxml2 2.9.12+ and libxslt 1.1.34 on Windows). * GH343: Windows-AArch64 build support in Visual Studio. Patch by Steve Dower. ``` ### 4.8.0 ``` ================== Features added -------------- * GH337: Path-like objects are now supported throughout the API instead of just strings. Patch by Henning Janssen. * The ``ElementMaker`` now supports ``QName`` values as tags, which always override the default namespace of the factory. Bugs fixed ---------- * GH338: In lxml.objectify, the XSI float annotation "nan" and "inf" were spelled in lower case, whereas XML Schema datatypes define them as "NaN" and "INF" respectively. Patch by Tobias Deiminger. Other changes ------------- * Built with Cython 0.29.28. ``` ### 4.7.1 ``` ================== Features added -------------- * Chunked Unicode string parsing via ``parser.feed()`` now encodes the input data to the native UTF-8 encoding directly, instead of going through ``Py_UNICODE`` / ``wchar_t`` encoding first, which previously required duplicate recoding in most cases. Bugs fixed ---------- * The standard namespace prefixes were mishandled during "C14N2" serialisation on Python 3. See https://mail.python.org/archives/list/lxmlpython.org/thread/6ZFBHFOVHOS5GFDOAMPCT6HM5HZPWQ4Q/ * ``lxml.objectify`` previously accepted non-XML numbers with underscores (like "1_000") as integers or float values in Python 3.6 and later. It now adheres to the number format of the XML spec again. * LP1939031: Static wheels of lxml now contain the header files of zlib and libiconv (in addition to the already provided headers of libxml2/libxslt/libexslt). Other changes ------------- * Wheels include libxml2 2.9.12+ and libxslt 1.1.34 (also on Windows). ``` ### 4.7.0 ``` ================== * Release retracted due to missing files in lxml/includes/. ``` ### 4.6.5 ``` ================== Bugs fixed ---------- * A vulnerability (GHSL-2021-1038) in the HTML cleaner allowed sneaking script content through SVG images (CVE-2021-43818). * A vulnerability (GHSL-2021-1037) in the HTML cleaner allowed sneaking script content through CSS imports and other crafted constructs (CVE-2021-43818). ``` ### 4.6.4 ``` ================== Features added -------------- * GH317: A new property ``system_url`` was added to DTD entities. Patch by Thirdegree. * GH314: The ``STATIC_*`` variables in ``setup.py`` can now be passed via env vars. Patch by Isaac Jurado. ```Links
- PyPI: https://pypi.org/project/lxml - Changelog: https://data.safetycli.com/changelogs/lxml/ - Homepage: https://lxml.de/