{
  "Selected_candidate": {
    "pr_number": 6159,
    "pr_title": "Fix #3859: manpage: code-block captions are not displayed correctly",
    "pr_body": "### Feature or Bugfix\r\n- Bugfix\r\n\r\n### Purpose\r\n- refs: #3859 \r\n",
    "issue_id": 3859,
    "issue_title": "code-block captions are not displayed correctly in man pages",
    "issue_body": "### Problem\r\ncode-block captions are not displayed correctly in man pages\r\n\r\n#### Procedure to reproduce the problem\r\nRun the following:\r\n```\r\nmkdir /tmp/code-block-test\r\ncd /tmp/code-block-test\r\nyes \"n\" | sphinx-quickstart --dot _ --project code-block-test --author \"Example\" -v 0 --release 0 --language en --suffix .rst --master index --makefile --batchfile docs\r\necho '\r\nBelow is an example of a codeblock with a caption.\r\n\r\n.. code-block:: bash\r\n   :caption: This is a caption\r\n\r\n   echo 1234\r\n' >> docs/index.rst\r\nmake -C docs man\r\n```\r\n\r\n#### Error logs / results\r\nThe rendered man page contains:\r\n```\r\n       Below is an example of a codeblock with a caption. This is a caption.INDENT 0.0\r\n\r\n          echo 1234\r\n```\r\n\r\n#### Expected results\r\n\".INDENT 0.0\" should not appear in the man page.\r\n\r\nI would expect the rendered version of the man page to look more like:\r\n\r\n```\r\n       Below is an example of a codeblock with a caption.\r\n\r\n       This is a caption\r\n\r\n          echo 1234\r\n```\r\n\r\n(This would be consistent with the behavior of `html` and `latexpdf`.)\r\n\r\n### Reproducible project / your project\r\nSee above.\r\n\r\n### Environment info\r\n- OS: Ubuntu 16.04 LTS\r\n- Python version: Python 2.7.12\r\n- Sphinx version: Sphinx v1.5.6",
    "issue_closed_at": "2019-03-10T06:24:55Z",
    "base_commit": "f57041ab000c6c2b1e672f3d963d849ecd3ee7ab",
    "changes": [
      {
        "file": "sphinx/writers/manpage.py",
        "type": "function",
        "name": "depart_manpage",
        "class_name": "ManualPageTranslator",
        "code": "def depart_manpage(self, node):\n        # type: (nodes.Node) -> None\n        return self.depart_strong(node)"
      }
    ]
  },
  "Justification": "Candidate B is most helpful because it directly involves the generation of man pages, which correlates closely with the CURRENT bug report regarding man page directory structure. Both reports highlight issues in the man page output, and the similar symptoms of incorrect rendering in the generated files point to underlying structural problems in how Sphinx handles man page creation. The fix discussed in Candidate B addresses formatting issues relevant to man pages generated by Sphinx, which could provide insights for fixing the directory structure issue in the CURRENT bug.",
  "instance_id": "sphinx-doc__sphinx-8273",
  "repo": "sphinx-doc/sphinx",
  "created_at": "2020-10-03T13:31:13Z",
  "problem_statement": "Generate man page section directories\n**Current man page generation does not conform to `MANPATH` search functionality**\r\nCurrently, all generated man pages are placed in to a single-level directory: `<build-dir>/man`. Unfortunately, this cannot be used in combination with the unix `MANPATH` environment variable. The `man` program explicitly looks for man pages in section directories (such as `man/man1`, etc.). \r\n\r\n**Describe the solution you'd like**\r\nIt would be great if sphinx would automatically create the section directories (e.g., `man/man1/`, `man/man3/`, etc.) and place each generated man page within appropriate section.\r\n\r\n**Describe alternatives you've considered**\r\nThis problem can be over come within our project’s build system, ensuring the built man pages are installed in a correct location, but it would be nice if the build directory had the proper layout.\r\n\r\nI’m happy to take a crack at implementing a fix, though this change in behavior may break some people who expect everything to appear in a `man/` directory. \r\n\n",
  "patch": "diff --git a/sphinx/builders/manpage.py b/sphinx/builders/manpage.py\n--- a/sphinx/builders/manpage.py\n+++ b/sphinx/builders/manpage.py\n@@ -24,7 +24,7 @@\n from sphinx.util import progress_message\n from sphinx.util.console import darkgreen  # type: ignore\n from sphinx.util.nodes import inline_all_toctrees\n-from sphinx.util.osutil import make_filename_from_project\n+from sphinx.util.osutil import ensuredir, make_filename_from_project\n from sphinx.writers.manpage import ManualPageWriter, ManualPageTranslator\n \n \n@@ -80,7 +80,12 @@ def write(self, *ignored: Any) -> None:\n             docsettings.authors = authors\n             docsettings.section = section\n \n-            targetname = '%s.%s' % (name, section)\n+            if self.config.man_make_section_directory:\n+                ensuredir(path.join(self.outdir, str(section)))\n+                targetname = '%s/%s.%s' % (section, name, section)\n+            else:\n+                targetname = '%s.%s' % (name, section)\n+\n             logger.info(darkgreen(targetname) + ' { ', nonl=True)\n             destination = FileOutput(\n                 destination_path=path.join(self.outdir, targetname),\n@@ -115,6 +120,7 @@ def setup(app: Sphinx) -> Dict[str, Any]:\n \n     app.add_config_value('man_pages', default_man_pages, None)\n     app.add_config_value('man_show_urls', False, None)\n+    app.add_config_value('man_make_section_directory', False, None)\n \n     return {\n         'version': 'builtin',\n"
}