mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Refs #36570 -- Added sphinxlint checker to flag unnecessary :py domain in documentation roles.
This commit is contained in:
		
							
								
								
									
										20
									
								
								docs/lint.py
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								docs/lint.py
									
									
									
									
									
								
							| @@ -5,12 +5,14 @@ from os.path import abspath, dirname, splitext | |||||||
| from unittest import mock | from unittest import mock | ||||||
|  |  | ||||||
| from sphinxlint.checkers import ( | from sphinxlint.checkers import ( | ||||||
|  |     _ROLE_BODY, | ||||||
|     _is_long_interpreted_text, |     _is_long_interpreted_text, | ||||||
|     _is_very_long_string_literal, |     _is_very_long_string_literal, | ||||||
|     _starts_with_anonymous_hyperlink, |     _starts_with_anonymous_hyperlink, | ||||||
|     _starts_with_directive_or_hyperlink, |     _starts_with_directive_or_hyperlink, | ||||||
| ) | ) | ||||||
| from sphinxlint.checkers import checker as sphinxlint_checker | from sphinxlint.checkers import checker as sphinxlint_checker | ||||||
|  | from sphinxlint.rst import SIMPLENAME | ||||||
| from sphinxlint.sphinxlint import check_text | from sphinxlint.sphinxlint import check_text | ||||||
| from sphinxlint.utils import PER_FILE_CACHES, hide_non_rst_blocks | from sphinxlint.utils import PER_FILE_CACHES, hide_non_rst_blocks | ||||||
|  |  | ||||||
| @@ -116,6 +118,24 @@ def check_line_too_long_django(file, lines, options=None): | |||||||
|             yield lno + 1, f"Line too long ({len(line) - 1}/{options.max_line_length})" |             yield lno + 1, f"Line too long ({len(line) - 1}/{options.max_line_length})" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | _PYTHON_DOMAIN = re.compile(f":py:{SIMPLENAME}:`{_ROLE_BODY}`") | ||||||
|  |  | ||||||
|  |  | ||||||
|  | @sphinxlint_checker(".rst", enabled=False, rst_only=True) | ||||||
|  | def check_python_domain_in_roles(file, lines, options=None): | ||||||
|  |     """ | ||||||
|  |     :py: indicates the Python language domain. This means code writen in | ||||||
|  |     Python, not Python built-ins in particular. | ||||||
|  |  | ||||||
|  |     Bad:    :py:class:`email.message.EmailMessage` | ||||||
|  |     Good:   :class:`email.message.EmailMessage` | ||||||
|  |     """ | ||||||
|  |     for lno, line in enumerate(lines, start=1): | ||||||
|  |         role = _PYTHON_DOMAIN.search(line) | ||||||
|  |         if role: | ||||||
|  |             yield lno, f":py domain is the default and can be omitted {role.group(0)!r}" | ||||||
|  |  | ||||||
|  |  | ||||||
| import sphinxlint  # noqa: E402 | import sphinxlint  # noqa: E402 | ||||||
|  |  | ||||||
| sphinxlint.check_file = django_check_file | sphinxlint.check_file = django_check_file | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user