{
    "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."
}