]> git.ipfire.org Git - thirdparty/Python/cpython.git/commit
gh-135661: Fix parsing start and end tags in HTMLParser according to the HTML5 standa...
authorSerhiy Storchaka <storchaka@gmail.com>
Thu, 3 Jul 2025 20:33:02 +0000 (23:33 +0300)
committerGitHub <noreply@github.com>
Thu, 3 Jul 2025 20:33:02 +0000 (23:33 +0300)
commit0243f97cbadec8d985e63b1daec5d1cbc850cae3
treefd467b4cdbdadde80a1b137c07607fa9c7598a79
parent938a5d7e62d962a8462bce9fe04236ac9a2155b8
gh-135661: Fix parsing start and end tags in HTMLParser according to the HTML5 standard (GH-135930)

* Whitespaces no longer accepted between `</` and the tag name.
  E.g. `</ script>` does not end the script section.

* Vertical tabulation (`\v`) and non-ASCII whitespaces no longer recognized
  as whitespaces. The only whitespaces are `\t\n\r\f `.

* Null character (U+0000) no longer ends the tag name.

* Attributes and slashes after the tag name in end tags are now ignored,
  instead of terminating after the first `>` in quoted attribute value.
  E.g. `</script/foo=">"/>`.

* Multiple slashes and whitespaces between the last attribute and closing `>`
  are now ignored in both start and end tags. E.g. `<a foo=bar/ //>`.

* Multiple `=` between attribute name and value are no longer collapsed.
  E.g. `<a foo==bar>` produces attribute "foo" with value "=bar".

* Whitespaces between the `=` separator and attribute name or value are no
  longer ignored. E.g. `<a foo =bar>` produces two attributes "foo" and
  "=bar", both with value None; `<a foo= bar>` produces two attributes:
  "foo" with value "" and "bar" with value None.

* Fix Sphinx errors.

* Apply suggestions from code review

Co-authored-by: Ezio Melotti <ezio.melotti@gmail.com>
* Address review comments.

* Move to Security.

---------

Co-authored-by: Ezio Melotti <ezio.melotti@gmail.com>
Lib/html/parser.py
Lib/test/test_htmlparser.py
Misc/NEWS.d/next/Security/2025-06-25-14-13-39.gh-issue-135661.idjQ0B.rst [new file with mode: 0644]