{
  "Selected_candidate": {
    "pr_number": 9699,
    "pr_title": "Close #9683: Revert the removal of ``add_stylesheet()`` API",
    "pr_body": "### Feature or Bugfix\r\n- Feature\r\n\r\n### Purpose\r\n- It will be kept until the Sphinx-6.0 release.\r\n- Note: Now it emits a warning instead of DeprecationWarning to let the\r\nusers know the deprecation.\r\n- refs: #9683 ",
    "issue_id": 9683,
    "issue_title": "app.add_stylesheet() is gone and replaced by app.add_css_file",
    "issue_body": "### Describe the bug\n\nThis breaks a LOT of projects. Please revert the removal.\r\n\r\nAs a package maintainer in Debian that is in charge of 500+ packages, this is not fun. There's no reason to deprecate and remove methods just because you think it's nicer. Please behave yourself. Nobody does that on the Linux kernel since its inception. It is unacceptable that breaking the world feels OK-ish to python developers, and shows a gave lack of seriousness.\n\n### How to Reproduce\n\nFor example, try to build pyroute2 with Sphinx 4.\n\n### Expected behavior\n\n_No response_\n\n### Your project\n\nDebian packaging of MANY packages\n\n### Screenshots\n\n_No response_\n\n### OS\n\ndebian\n\n### Python version\n\n3.9\n\n### Sphinx version\n\n4.2.0\n\n### Sphinx extensions\n\n_No response_\n\n### Extra tools\n\n_No response_\n\n### Additional context\n\n_No response_",
    "issue_closed_at": "2021-10-09T06:12:45Z",
    "base_commit": "f050a7775dfc9000f55d023d36d925a8d02ccfa8",
    "changes": [
      {
        "file": "sphinx/application.py",
        "type": "function",
        "name": "add_css_file",
        "class_name": "Sphinx",
        "code": "def add_css_file(self, filename: str, priority: int = 500, **kwargs: Any) -> None:\n        \"\"\"Register a stylesheet to include in the HTML output.\n\n        Add *filename* to the list of CSS files that the default HTML template\n        will include in order of *priority* (ascending).  The filename must be\n        relative to the HTML static path, or a full URI with scheme.  If the\n        priority of the CSS file is the same as others, the CSS files will be\n        included in order of registration.  The keyword arguments are also\n        accepted for attributes of ``<link>`` tag.\n\n        Example::\n\n            app.add_css_file('custom.css')\n            # => <link rel=\"stylesheet\" href=\"_static/custom.css\" type=\"text/css\" />\n\n            app.add_css_file('print.css', media='print')\n            # => <link rel=\"stylesheet\" href=\"_static/print.css\"\n            #          type=\"text/css\" media=\"print\" />\n\n            app.add_css_file('fancy.css', rel='alternate stylesheet', title='fancy')\n            # => <link rel=\"alternate stylesheet\" href=\"_static/fancy.css\"\n            #          type=\"text/css\" title=\"fancy\" />\n\n        .. list-table:: priority range for CSS files\n           :widths: 20,80\n\n           * - Priority\n             - Main purpose in Sphinx\n           * - 200\n             - default priority for built-in CSS files\n           * - 500\n             - default priority for extensions\n           * - 800\n             - default priority for :confval:`html_css_files`\n\n        A CSS file can be added to the specific HTML page when an extension calls\n        this method on :event:`html-page-context` event.\n\n        .. versionadded:: 1.0\n\n        .. versionchanged:: 1.6\n           Optional ``alternate`` and/or ``title`` attributes can be supplied\n           with the arguments *alternate* (a Boolean) and *title* (a string).\n           The default is no title and *alternate* = ``False``. For\n           more information, refer to the `documentation\n           <https://mdn.io/Web/CSS/Alternative_style_sheets>`__.\n\n        .. versionchanged:: 1.8\n           Renamed from ``app.add_stylesheet()``.\n           And it allows keyword arguments as attributes of link tag.\n\n        .. versionchanged:: 3.5\n           Take priority argument.  Allow to add a CSS file to the specific page.\n        \"\"\"\n        logger.debug('[app] adding stylesheet: %r', filename)\n        self.registry.add_css_files(filename, priority=priority, **kwargs)\n        if hasattr(self.builder, 'add_css_file'):\n            self.builder.add_css_file(filename, priority=priority, **kwargs)"
      }
    ]
  },
  "Justification": "Candidate C is the most helpful because it specifically addresses issues related to Sphinx documentation that could arise during builds, similar to the rendering problem identified in the CURRENT bug. Both reports involve unexpected changes to the Sphinx API and impacts on how documentation is processed, suggesting a similar underlying issue in handling document structure and directives. Since the CURRENT bug also involves rendering issues related to directives in `.rst` files, insights gained from how other breaking changes were addressed in Candidate C could directly inform the debugging process for the CURRENT bug.",
  "instance_id": "sphinx-doc__sphinx-11445",
  "repo": "sphinx-doc/sphinx",
  "created_at": "2023-05-28T19:15:07Z",
  "problem_statement": "Using rst_prolog removes top level headings containing a domain directive\n### Describe the bug\r\n\r\nIf `rst_prolog` is set, then any documents that contain a domain directive as the first heading (eg `:mod:`) do not render the heading correctly or include the heading in the toctree.\r\n\r\nIn the example below, if the heading of `docs/mypackage.rst` were `mypackage2` instead of `:mod:mypackage2` then the heading displays correctly.\r\nSimilarly, if you do not set `rst_prolog` then the heading will display correctly.\r\n\r\nThis appears to have been broken for some time because I can reproduce it in v4.0.0 of Sphinx\r\n\r\n### How to Reproduce\r\n\r\n```bash\r\n$ sphinx-quickstart --no-sep --project mypackage --author me -v 0.1.0 --release 0.1.0 --language en docs\r\n$ echo -e 'Welcome\\n=======\\n\\n.. toctree::\\n\\n   mypackage\\n' > docs/index.rst\r\n$ echo -e ':mod:`mypackage2`\\n=================\\n\\nContent\\n\\nSubheading\\n----------\\n' > docs/mypackage.rst\r\n$ echo -e 'rst_prolog = \"\"\"\\n.. |psf| replace:: Python Software Foundation\\n\"\"\"\\n' >> docs/conf.py\r\n$ sphinx-build -b html . _build\r\n$ grep 'mypackage2' docs/_build/index.html\r\n```\r\n\r\n`docs/index.rst`:\r\n\r\n```rst\r\nWelcome\r\n=======\r\n\r\n.. toctree::\r\n\r\n   mypackage\r\n```\r\n\r\n`docs/mypackage.rst`:\r\n\r\n```rst\r\n:mod:`mypackage2`\r\n=================\r\n\r\nContent\r\n\r\nSubheading\r\n----------\r\n```\r\n\r\n### Environment Information\r\n\r\n```text\r\nPlatform:              linux; (Linux-6.3.2-arch1-1-x86_64-with-glibc2.37)\r\nPython version:        3.11.3 (main, Apr  5 2023, 15:52:25) [GCC 12.2.1 20230201])\r\nPython implementation: CPython\r\nSphinx version:        7.1.0+/d3c91f951\r\nDocutils version:      0.20.1\r\nJinja2 version:        3.1.2\r\nPygments version:      2.15.1\r\n```\r\n\r\n\r\n### Sphinx extensions\r\n\r\n```python\r\n[]\r\n```\r\n\r\n\r\n### Additional context\r\n\r\n_No response_\n",
  "patch": "diff --git a/sphinx/util/rst.py b/sphinx/util/rst.py\n--- a/sphinx/util/rst.py\n+++ b/sphinx/util/rst.py\n@@ -10,22 +10,17 @@\n \n from docutils.parsers.rst import roles\n from docutils.parsers.rst.languages import en as english\n+from docutils.parsers.rst.states import Body\n from docutils.statemachine import StringList\n from docutils.utils import Reporter\n-from jinja2 import Environment\n+from jinja2 import Environment, pass_environment\n \n from sphinx.locale import __\n from sphinx.util import docutils, logging\n \n-try:\n-    from jinja2.utils import pass_environment\n-except ImportError:\n-    from jinja2 import environmentfilter as pass_environment\n-\n-\n logger = logging.getLogger(__name__)\n \n-docinfo_re = re.compile(':\\\\w+:.*?')\n+FIELD_NAME_RE = re.compile(Body.patterns['field_marker'])\n symbols_re = re.compile(r'([!-\\-/:-@\\[-`{-~])')  # symbols without dot(0x2e)\n SECTIONING_CHARS = ['=', '-', '~']\n \n@@ -80,7 +75,7 @@ def prepend_prolog(content: StringList, prolog: str) -> None:\n     if prolog:\n         pos = 0\n         for line in content:\n-            if docinfo_re.match(line):\n+            if FIELD_NAME_RE.match(line):\n                 pos += 1\n             else:\n                 break\n@@ -91,6 +86,7 @@ def prepend_prolog(content: StringList, prolog: str) -> None:\n             pos += 1\n \n         # insert prolog (after docinfo if exists)\n+        lineno = 0\n         for lineno, line in enumerate(prolog.splitlines()):\n             content.insert(pos + lineno, line, '<rst_prolog>', lineno)\n \n"
}