{
  "original_problem": {
    "instance_id": "matplotlib__matplotlib-18869",
    "repo": "matplotlib/matplotlib",
    "created_at": "2020-11-01T23:18:42Z",
    "problem_statement": "Add easily comparable version info to toplevel\n<!--\r\nWelcome! Thanks for thinking of a way to improve Matplotlib.\r\n\r\n\r\nBefore creating a new feature request please search the issues for relevant feature requests.\r\n-->\r\n\r\n### Problem\r\n\r\nCurrently matplotlib only exposes `__version__`.  For quick version checks, exposing either a `version_info` tuple (which can be compared with other tuples) or a `LooseVersion` instance (which can be properly compared with other strings) would be a small usability improvement.\r\n\r\n(In practice I guess boring string comparisons will work just fine until we hit mpl 3.10 or 4.10 which is unlikely to happen soon, but that feels quite dirty :))\r\n<!--\r\nProvide a clear and concise description of the problem this feature will solve. \r\n\r\nFor example:\r\n* I'm always frustrated when [...] because [...]\r\n* I would like it if [...] happened when I [...] because [...]\r\n* Here is a sample image of what I am asking for [...]\r\n-->\r\n\r\n### Proposed Solution\r\n\r\nI guess I slightly prefer `LooseVersion`, but exposing just a `version_info` tuple is much more common in other packages (and perhaps simpler to understand).  The hardest(?) part is probably just bikeshedding this point :-)\r\n<!-- Provide a clear and concise description of a way to accomplish what you want. For example:\r\n\r\n* Add an option so that when [...]  [...] will happen\r\n -->\r\n\r\n### Additional context and prior art\r\n\r\n`version_info` is a pretty common thing (citation needed).\r\n<!-- Add any other context or screenshots about the feature request here. You can also include links to examples of other programs that have something similar to your request. For example:\r\n\r\n* Another project [...] solved this by [...]\r\n-->\r\n\n",
    "patch": "diff --git a/lib/matplotlib/__init__.py b/lib/matplotlib/__init__.py\n--- a/lib/matplotlib/__init__.py\n+++ b/lib/matplotlib/__init__.py\n@@ -129,25 +129,60 @@\n   year      = 2007\n }\"\"\"\n \n+# modelled after sys.version_info\n+_VersionInfo = namedtuple('_VersionInfo',\n+                          'major, minor, micro, releaselevel, serial')\n \n-def __getattr__(name):\n-    if name == \"__version__\":\n+\n+def _parse_to_version_info(version_str):\n+    \"\"\"\n+    Parse a version string to a namedtuple analogous to sys.version_info.\n+\n+    See:\n+    https://packaging.pypa.io/en/latest/version.html#packaging.version.parse\n+    https://docs.python.org/3/library/sys.html#sys.version_info\n+    \"\"\"\n+    v = parse_version(version_str)\n+    if v.pre is None and v.post is None and v.dev is None:\n+        return _VersionInfo(v.major, v.minor, v.micro, 'final', 0)\n+    elif v.dev is not None:\n+        return _VersionInfo(v.major, v.minor, v.micro, 'alpha', v.dev)\n+    elif v.pre is not None:\n+        releaselevel = {\n+            'a': 'alpha',\n+            'b': 'beta',\n+            'rc': 'candidate'}.get(v.pre[0], 'alpha')\n+        return _VersionInfo(v.major, v.minor, v.micro, releaselevel, v.pre[1])\n+    else:\n+        # fallback for v.post: guess-next-dev scheme from setuptools_scm\n+        return _VersionInfo(v.major, v.minor, v.micro + 1, 'alpha', v.post)\n+\n+\n+def _get_version():\n+    \"\"\"Return the version string used for __version__.\"\"\"\n+    # Only shell out to a git subprocess if really needed, and not on a\n+    # shallow clone, such as those used by CI, as the latter would trigger\n+    # a warning from setuptools_scm.\n+    root = Path(__file__).resolve().parents[2]\n+    if (root / \".git\").exists() and not (root / \".git/shallow\").exists():\n         import setuptools_scm\n+        return setuptools_scm.get_version(\n+            root=root,\n+            version_scheme=\"post-release\",\n+            local_scheme=\"node-and-date\",\n+            fallback_version=_version.version,\n+        )\n+    else:  # Get the version from the _version.py setuptools_scm file.\n+        return _version.version\n+\n+\n+def __getattr__(name):\n+    if name in (\"__version__\", \"__version_info__\"):\n         global __version__  # cache it.\n-        # Only shell out to a git subprocess if really needed, and not on a\n-        # shallow clone, such as those used by CI, as the latter would trigger\n-        # a warning from setuptools_scm.\n-        root = Path(__file__).resolve().parents[2]\n-        if (root / \".git\").exists() and not (root / \".git/shallow\").exists():\n-            __version__ = setuptools_scm.get_version(\n-                root=root,\n-                version_scheme=\"post-release\",\n-                local_scheme=\"node-and-date\",\n-                fallback_version=_version.version,\n-            )\n-        else:  # Get the version from the _version.py setuptools_scm file.\n-            __version__ = _version.version\n-        return __version__\n+        __version__ = _get_version()\n+        global __version__info__  # cache it.\n+        __version_info__ = _parse_to_version_info(__version__)\n+        return __version__ if name == \"__version__\" else __version_info__\n     raise AttributeError(f\"module {__name__!r} has no attribute {name!r}\")\n \n \n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_16280",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue focuses on rendering and normalization, unrelated to version information handling."
      },
      {
        "idx": 2,
        "id": "similar_18327",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue deals with GUI customization and icon handling, not relevant to version information management."
      },
      {
        "idx": 3,
        "id": "similar_18292",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue is about dependency management and DLL loading, unrelated to version information exposure."
      },
      {
        "idx": 4,
        "id": "similar_15103",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue involves handling masked arrays and interactive features, not applicable to version information."
      },
      {
        "idx": 5,
        "id": "similar_4185",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue concerns vector graphics rendering, which does not relate to version information handling."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "SymLogNorm colorbar incorrect on master",
        "issue_body": "<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\n<!--A short 1-2 sentences that succinctly describes the bug-->\r\n\r\nThe colormap/tick locations within the colorbar are not being updated properly with a SymLogNorm on master. I think this is different than #16269 because it is actually creating the colorbar, just a wrong one.\r\n\r\nCompare the previous correct version:\r\nhttps://matplotlib.org/3.1.0/gallery/userdemo/colormap_normalizations_symlognorm.html\r\n\r\nwith a fresh checkout of master:\r\n\r\n![test](https://user-images.githubusercontent.com/12417828/72822693-c38abb80-3c2f-11ea-89f9-a101191d7bb3.png)\r\n\r\nDifference in the colorbar of the top axis.",
        "issue_id": 16280,
        "pr_number": 16392,
        "pr_title": "FIX colorbars for Norms that do not have a scale.",
        "pr_body": "## PR Summary\r\n\r\nIf a norm that did not have a corresponding scale is used, then the colorbar was not working.  This PR (thanks @dstansby) now keeps track of the scale associated with the colorbar and if it is \"manual\" then falls back to the manual method of creating the colorbar.  \r\n\r\nReplaces #16286\r\n\r\nCloses #16280 \r\n\r\nNote there are still issues with SymLogNorm, but this fix is regardless of that.  \r\n\r\n## PR Checklist\r\n\r\n- [ ] Has Pytest style unit tests\r\n- [ ] Code is [Flake 8](http://flake8.pycqa.org/en/latest/) compliant\r\n- [ ] New features are documented, with examples if plot related\r\n- [ ] Documentation is sphinx and numpydoc compliant\r\n- [ ] Added an entry to doc/users/next_whats_new/ if major new feature (follow instructions in README.rst there)\r\n- [ ] Documented in doc/api/api_changes.rst if API changed in a backward-incompatible way\r\n\r\n<!--\r\nThank you so much for your PR!  To help us review your contribution, please\r\nconsider the following points:\r\n\r\n- A development guide is available at https://matplotlib.org/devdocs/devel/index.html.\r\n\r\n- Help with git and github is available at\r\n  https://matplotlib.org/devel/gitwash/development_workflow.html.\r\n\r\n- Do not create the PR out of master, but out of a separate branch.\r\n\r\n- The PR title should summarize the changes, for example \"Raise ValueError on\r\n  non-numeric input to set_xlim\".  Avoid non-descriptive titles such as\r\n  \"Addresses issue #8576\".\r\n\r\n- The summary should provide at least 1-2 sentences describing the pull request\r\n  in detail (Why is this change required?  What problem does it solve?) and\r\n  link to any relevant issues.\r\n\r\n- If you are contributing fixes to docstrings, please pay attention to\r\n  http://matplotlib.org/devel/documenting_mpl.html#formatting.  In particular,\r\n  note the difference between using single backquotes, double backquotes, and\r\n  asterisks in the markup.\r\n\r\nWe understand that PRs can sometimes be overwhelming, especially as the\r\nreviews start coming in.  Please let us know if the reviews are unclear or\r\nthe recommended next step seems overly demanding, if you would like help in\r\naddressing a reviewer's comments, or if you have been waiting too long to hear\r\nback on your PR.\r\n-->\r\n",
        "issue_closed_at": "2020-02-10T20:35:02Z",
        "base_commit": "cb904b187370119e965e5fe811f796772647e7df"
      },
      "summary": "### Summary:\n\nThis issue is related to the incorrect rendering of colorbars when using the SymLogNorm normalization in the Matplotlib library. The problem is specifically observed in the master branch of the code where the colorbar and its tick locations do not update correctly, resulting in a display that does not match previous versions. The key symptom is the discrepancy between the expected colorbar appearance and the generated one, particularly noticeable in the top axis of a plot. \n\nThe affected components include the colorbar generation and normalization functionality within Matplotlib, primarily involving functions responsible for initializing and resetting colorbar locators and formatters. This issue can lead to incorrect data visualization, potentially affecting data interpretation and analysis. It is a significant concern for users relying on accurate graphical representation of data with logarithmic scaling. \n\nThe technical resolution involved updates to functions within `lib/matplotlib/colorbar.py`, specifically `ColorbarPatch.__init__`, `ColorbarBase._use_auto_colorbar_locator`, `ColorbarBase._reset_locator_formatter_scale`, and `ColorbarBase._mesh`, which are responsible for handling the colorbar creation and its scale adjustments. The patch ensures that colorbars generated with SymLogNorm are now accurately reflecting the intended visual output.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: SymLogNorm colorbar incorrect on master\n\nBody:\n<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\n<!--A short 1-2 sentences that succinctly describes the bug-->\r\n\r\nThe colormap/tick locations within the colorbar are not being updated properly with a SymLogNorm on master. I think this is different than #16269 because it is actually creating the colorbar, just a wrong one.\r\n\r\nCompare the previous correct version:\r\nhttps://matplotlib.org/3.1.0/gallery/userdemo/colormap_normalizations_symlognorm.html\r\n\r\nwith a fresh checkout of master:\r\n\r\n![test](https://user-images.githubusercontent.com/12417828/72822693-c38abb80-3c2f-11ea-89f9-a101191d7bb3.png)\r\n\r\nDifference in the colorbar of the top axis.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/colorbar.py\n  function: ColorbarPatch.__init__\n  function: ColorbarBase._use_auto_colorbar_locator\n  function: ColorbarBase._reset_locator_formatter_scale\n  function: ColorbarBase._mesh\n"
    },
    {
      "similar_issue": {
        "issue_title": "Tool Manager: adding buttons to toolbar fails with matplotlib version 3.3.1 using Qt backend",
        "issue_body": "### Bug report\r\n\r\nAdding buttons on the toolbar in matplotlib version 3.3.1 produces `AttributeError` with `Qt5Agg` backend.\r\n\r\n**Code for reproduction**\r\nThe easiest way to reproduce: from the [original example gallery](https://matplotlib.org/gallery/user_interfaces/toolmanager_sgskip.html?highlight=tool%20manager):\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nplt.rcParams['toolbar'] = 'toolmanager'\r\nfrom matplotlib.backend_tools import ToolBase, ToolToggleBase\r\n\r\nplt.switch_backend(\"Qt5Agg\")\r\n\r\nclass ListTools(ToolBase):\r\n    \"\"\"List all the tools controlled by the `ToolManager`.\"\"\"\r\n    # keyboard shortcut\r\n    default_keymap = 'm'\r\n    description = 'List Tools'\r\n\r\n    def trigger(self, *args, **kwargs):\r\n        print('_' * 80)\r\n        print(\"{0:12} {1:45} {2}\".format(\r\n            'Name (id)', 'Tool description', 'Keymap'))\r\n        print('-' * 80)\r\n        tools = self.toolmanager.tools\r\n        for name in sorted(tools):\r\n            if not tools[name].description:\r\n                continue\r\n            keys = ', '.join(sorted(self.toolmanager.get_tool_keymap(name)))\r\n            print(\"{0:12} {1:45} {2}\".format(\r\n                name, tools[name].description, keys))\r\n        print('_' * 80)\r\n        print(\"Active Toggle tools\")\r\n        print(\"{0:12} {1:45}\".format(\"Group\", \"Active\"))\r\n        print('-' * 80)\r\n        for group, active in self.toolmanager.active_toggle.items():\r\n            print(\"{0:12} {1:45}\".format(str(group), str(active)))\r\n\r\n\r\nclass GroupHideTool(ToolToggleBase):\r\n    \"\"\"Show lines with a given gid.\"\"\"\r\n    default_keymap = 'G'\r\n    description = 'Show by gid'\r\n    default_toggled = True\r\n\r\n    def __init__(self, *args, gid, **kwargs):\r\n        self.gid = gid\r\n        super().__init__(*args, **kwargs)\r\n\r\n    def enable(self, *args):\r\n        self.set_lines_visibility(True)\r\n\r\n    def disable(self, *args):\r\n        self.set_lines_visibility(False)\r\n\r\n    def set_lines_visibility(self, state):\r\n        for ax in self.figure.get_axes():\r\n            for line in ax.get_lines():\r\n                if line.get_gid() == self.gid:\r\n                    line.set_visible(state)\r\n        self.figure.canvas.draw()\r\n\r\n\r\nfig = plt.figure()\r\nplt.plot([1, 2, 3], gid='mygroup')\r\nplt.plot([2, 3, 4], gid='unknown')\r\nplt.plot([3, 2, 1], gid='mygroup')\r\n\r\n# Add the custom tools that we created\r\nfig.canvas.manager.toolmanager.add_tool('List', ListTools)\r\nfig.canvas.manager.toolmanager.add_tool('Show', GroupHideTool, gid='mygroup')\r\n\r\n\r\n# Add an existing tool to new group `foo`.\r\n# It can be added as many times as we want\r\nfig.canvas.manager.toolbar.add_tool('zoom', 'foo')\r\n\r\n# Remove the forward button\r\nfig.canvas.manager.toolmanager.remove_tool('forward')\r\n\r\n# To add a custom tool to the toolbar at specific location inside\r\n# the navigation group\r\nfig.canvas.manager.toolbar.add_tool('Show', 'navigation', 1)\r\n\r\nplt.show()\r\n```\r\n\r\n**Actual outcome**\r\n\r\n```\r\nTreat the new Tool classes introduced in v1.5 as experimental for now, the API will likely change in version 2.1 and perhaps the rcParam as well\r\nE:\\mpl_toolbar_issue.py:57: UserWarning: The new Tool classes introduced in v1.5 are experimental; their API (including names) will likely change in future versions.\r\n  fig = plt.figure()\r\nE:\\mpl_toolbar_issue.py:63: UserWarning: The new Tool classes introduced in v1.5 are experimental; their API (including names) will likely change in future versions.\r\n  fig.canvas.manager.toolmanager.add_tool('List', ListTools)\r\nE:\\mpl_toolbar_issue.py:41: UserWarning: The new Tool classes introduced in v1.5 are experimental; their API (including names) will likely change in future versions.\r\n  super().__init__(*args, **kwargs)\r\nE:\\mpl_toolbar_issue.py:64: UserWarning: Key G changed from grid_minor to Show\r\n  fig.canvas.manager.toolmanager.add_tool('Show', GroupHideTool, gid='mygroup')\r\nTraceback (most recent call last):\r\n  File \"E:\\mpl_toolbar_issue.py\", line 76, in <module>\r\n    fig.canvas.manager.toolbar.add_tool('Show', 'navigation', 1)\r\n  File \"C:\\Program Files\\Python37\\lib\\site-packages\\matplotlib\\backend_bases.py\", line 3333, in add_tool\r\n    image, tool.description, toggle)\r\n  File \"C:\\Program Files\\Python37\\lib\\site-packages\\matplotlib\\backends\\backend_qt5.py\", line 919, in add_toolitem\r\n    button.setIcon(NavigationToolbar2QT._icon(self, image_file))\r\n  File \"C:\\Program Files\\Python37\\lib\\site-packages\\matplotlib\\backends\\backend_qt5.py\", line 711, in _icon\r\n    name = name.replace('.png', '_large.png')\r\nAttributeError: 'NoneType' object has no attribute 'replace'\r\n```\r\n\r\nHowever, running it on  for example `TkAgg` backend works fine. I also downgraded to `3.3.0` and it seems to fix the issue, so I think something is broken in release `3.3.1`.\r\n\r\n**Matplotlib version**\r\n  * Operating system: Windows 10\r\n  * Matplotlib version: 3.3.1\r\n  * Matplotlib backend: Qt5Agg\r\n  * Python version: 3.7.6\r\n\r\nI installed matplotlib 3.3.1 on pip and conda as well, and it seems broken on both.\r\n",
        "issue_id": 18327,
        "pr_number": 18328,
        "pr_title": "Add missing check for None in Qt toolmanager.",
        "pr_body": "(The fix is already there in all other backends.)\r\ncloses #18327; adding tests is tracked as https://github.com/matplotlib/matplotlib/issues/17999.\r\n\r\n## PR Summary\r\n\r\n## PR Checklist\r\n\r\n- [ ] Has Pytest style unit tests\r\n- [ ] Code is [Flake 8](http://flake8.pycqa.org/en/latest/) compliant\r\n- [ ] New features are documented, with examples if plot related\r\n- [ ] Documentation is sphinx and numpydoc compliant\r\n- [ ] Added an entry to doc/users/next_whats_new/ if major new feature (follow instructions in README.rst there)\r\n- [ ] Documented in doc/api/next_api_changes/* if API changed in a backward-incompatible way\r\n\r\n<!--\r\nThank you so much for your PR!  To help us review your contribution, please\r\nconsider the following points:\r\n\r\n- A development guide is available at https://matplotlib.org/devdocs/devel/index.html.\r\n\r\n- Help with git and github is available at\r\n  https://matplotlib.org/devel/gitwash/development_workflow.html.\r\n\r\n- Do not create the PR out of master, but out of a separate branch.\r\n\r\n- The PR title should summarize the changes, for example \"Raise ValueError on\r\n  non-numeric input to set_xlim\".  Avoid non-descriptive titles such as\r\n  \"Addresses issue #8576\".\r\n\r\n- The summary should provide at least 1-2 sentences describing the pull request\r\n  in detail (Why is this change required?  What problem does it solve?) and\r\n  link to any relevant issues.\r\n\r\n- If you are contributing fixes to docstrings, please pay attention to\r\n  http://matplotlib.org/devel/documenting_mpl.html#formatting.  In particular,\r\n  note the difference between using single backquotes, double backquotes, and\r\n  asterisks in the markup.\r\n\r\nWe understand that PRs can sometimes be overwhelming, especially as the\r\nreviews start coming in.  Please let us know if the reviews are unclear or\r\nthe recommended next step seems overly demanding, if you would like help in\r\naddressing a reviewer's comments, or if you have been waiting too long to hear\r\nback on your PR.\r\n-->\r\n",
        "issue_closed_at": "2020-08-23T15:43:19Z",
        "base_commit": "48b63273f940e9745010655f50078210afd3d0ea"
      },
      "summary": "### Summary:\nThis issue is related to the integration of custom buttons into the toolbar when using Matplotlib version 3.3.1 with the Qt5Agg backend. The problem manifests as an `AttributeError` when attempting to add a custom tool to the toolbar, specifically due to a failure in handling icon files.\n\n1. **Problem Description in General Terms:**\n   The problem arises when attempting to extend the functionality of a graphical user interface by adding custom tools to a toolbar using a specific version of a visualization library in a Python environment. The issue appears to be specific to the use of certain graphical backends and library versions, causing tool addition failures.\n\n2. **Key Symptoms and Behaviors Observed:**\n   The primary symptom is an `AttributeError` triggered when the application attempts to set an icon for a toolbar button. The error suggests that a `NoneType` object is being processed instead of a valid image file, leading to a crash. Additionally, there are user warnings about the experimental nature of new Tool classes, indicating potential instability in the API.\n\n3. **Affected Components or Systems:**\n   The affected components include Matplotlib's Qt5Agg backend and its toolbar management system within version 3.3.1. The issue specifically affects the customization capabilities of the toolbar using user-defined tools in this environment.\n\n4. **Potential Impact or Severity:**\n   The impact is moderate, as it prevents users from adding new functionality to the toolbar, potentially hindering the development of more advanced data visualization applications. It may affect developers relying on toolbar customization for user interfaces in scientific or analytical software.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   The underlying problem seems to stem from changes or bugs introduced in version 3.3.1 of Matplotlib. The issue is specific to the Qt5Agg backend and involves the handling of image files for toolbar icons. The problem does not occur with other backends, such as TkAgg, or with earlier versions like 3.3.0, suggesting a regression in the recent update.\n\nThe resolution of this issue involves correcting the handling of icon files within the `ToolbarQt.add_toolitem` function in the backend_qt5.py module.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Tool Manager: adding buttons to toolbar fails with matplotlib version 3.3.1 using Qt backend\n\nBody:\n### Bug report\r\n\r\nAdding buttons on the toolbar in matplotlib version 3.3.1 produces `AttributeError` with `Qt5Agg` backend.\r\n\r\n**Code for reproduction**\r\nThe easiest way to reproduce: from the [original example gallery](https://matplotlib.org/gallery/user_interfaces/toolmanager_sgskip.html?highlight=tool%20manager):\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nplt.rcParams['toolbar'] = 'toolmanager'\r\nfrom matplotlib.backend_tools import ToolBase, ToolToggleBase\r\n\r\nplt.switch_backend(\"Qt5Agg\")\r\n\r\nclass ListTools(ToolBase):\r\n    \"\"\"List all the tools controlled by the `ToolManager`.\"\"\"\r\n    # keyboard shortcut\r\n    default_keymap = 'm'\r\n    description = 'List Tools'\r\n\r\n    def trigger(self, *args, **kwargs):\r\n        print('_' * 80)\r\n        print(\"{0:12} {1:45} {2}\".format(\r\n            'Name (id)', 'Tool description', 'Keymap'))\r\n        print('-' * 80)\r\n        tools = self.toolmanager.tools\r\n        for name in sorted(tools):\r\n            if not tools[name].description:\r\n                continue\r\n            keys = ', '.join(sorted(self.toolmanager.get_tool_keymap(name)))\r\n            print(\"{0:12} {1:45} {2}\".format(\r\n                name, tools[name].description, keys))\r\n        print('_' * 80)\r\n        print(\"Active Toggle tools\")\r\n        print(\"{0:12} {1:45}\".format(\"Group\", \"Active\"))\r\n        print('-' * 80)\r\n        for group, active in self.toolmanager.active_toggle.items():\r\n            print(\"{0:12} {1:45}\".format(str(group), str(active)))\r\n\r\n\r\nclass GroupHideTool(ToolToggleBase):\r\n    \"\"\"Show lines with a given gid.\"\"\"\r\n    default_keymap = 'G'\r\n    description = 'Show by gid'\r\n    default_toggled = True\r\n\r\n    def __init__(self, *args, gid, **kwargs):\r\n        self.gid = gid\r\n        super().__init__(*args, **kwargs)\r\n\r\n    def enable(self, *args):\r\n        self.set_lines_visibility(True)\r\n\r\n    def disable(self, *args):\r\n        self.set_lines_visibility(False)\r\n\r\n    def set_lines_visibility(self, state):\r\n        for ax in self.figure.get_axes():\r\n            for line in ax.get_lines():\r\n                if line.get_gid() == self.gid:\r\n                    line.set_visible(state)\r\n        self.figure.canvas.draw()\r\n\r\n\r\nfig = plt.figure()\r\nplt.plot([1, 2, 3], gid='mygroup')\r\nplt.plot([2, 3, 4], gid='unknown')\r\nplt.plot([3, 2, 1], gid='mygroup')\r\n\r\n# Add the custom tools that we created\r\nfig.canvas.manager.toolmanager.add_tool('List', ListTools)\r\nfig.canvas.manager.toolmanager.add_tool('Show', GroupHideTool, gid='mygroup')\r\n\r\n\r\n# Add an existing tool to new group `foo`.\r\n# It can be added as many times as we want\r\nfig.canvas.manager.toolbar.add_tool('zoom', 'foo')\r\n\r\n# Remove the forward button\r\nfig.canvas.manager.toolmanager.remove_tool('forward')\r\n\r\n# To add a custom tool to the toolbar at specific location inside\r\n# the navigation group\r\nfig.canvas.manager.toolbar.add_tool('Show', 'navigation', 1)\r\n\r\nplt.show()\r\n```\r\n\r\n**Actual outcome**\r\n\r\n```\r\nTreat the new Tool classes introduced in v1.5 as experimental for now, the API will likely change in version 2.1 and perhaps the rcParam as well\r\nE:\\mpl_toolbar_issue.py:57: UserWarning: The new Tool classes introduced in v1.5 are experimental; their API (including names) will likely change in future versions.\r\n  fig = plt.figure()\r\nE:\\mpl_toolbar_issue.py:63: UserWarning: The new Tool classes introduced in v1.5 are experimental; their API (including names) will likely change in future versions.\r\n  fig.canvas.manager.toolmanager.add_tool('List', ListTools)\r\nE:\\mpl_toolbar_issue.py:41: UserWarning: The new Tool classes introduced in v1.5 are experimental; their API (including names) will likely change in future versions.\r\n  super().__init__(*args, **kwargs)\r\nE:\\mpl_toolbar_issue.py:64: UserWarning: Key G changed from grid_minor to Show\r\n  fig.canvas.manager.toolmanager.add_tool('Show', GroupHideTool, gid='mygroup')\r\nTraceback (most recent call last):\r\n  File \"E:\\mpl_toolbar_issue.py\", line 76, in <module>\r\n    fig.canvas.manager.toolbar.add_tool('Show', 'navigation', 1)\r\n  File \"C:\\Program Files\\Python37\\lib\\site-packages\\matplotlib\\backend_bases.py\", line 3333, in add_tool\r\n    image, tool.description, toggle)\r\n  File \"C:\\Program Files\\Python37\\lib\\site-packages\\matplotlib\\backends\\backend_qt5.py\", line 919, in add_toolitem\r\n    button.setIcon(NavigationToolbar2QT._icon(self, image_file))\r\n  File \"C:\\Program Files\\Python37\\lib\\site-packages\\matplotlib\\backends\\backend_qt5.py\", line 711, in _icon\r\n    name = name.replace('.png', '_large.png')\r\nAttributeError: 'NoneType' object has no attribute 'replace'\r\n```\r\n\r\nHowever, running it on  for example `TkAgg` backend works fine. I also downgraded to `3.3.0` and it seems to fix the issue, so I think something is broken in release `3.3.1`.\r\n\r\n**Matplotlib version**\r\n  * Operating system: Windows 10\r\n  * Matplotlib version: 3.3.1\r\n  * Matplotlib backend: Qt5Agg\r\n  * Python version: 3.7.6\r\n\r\nI installed matplotlib 3.3.1 on pip and conda as well, and it seems broken on both.\r\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/backends/backend_qt5.py\n  function: ToolbarQt.add_toolitem\n"
    },
    {
      "similar_issue": {
        "issue_title": "ImportError: DLL load failed with Matplotlib 3.3.1 on Windows",
        "issue_body": "<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nOn some Windows machines (including Windows 10 and Windows 7), we experienced `ImportError: DLL load failed: The specific module could not be found` after upgrading from Matplotlib 3.3.0 to 3.3.1. \r\n\r\n**Code for reproduction**\r\n\r\n`import matplotlib` would trigger the import error while trying to import ft2font.\r\n\r\n\r\n**Actual outcome**\r\n\r\n```python\r\nIn [1]: import matplotlib\r\n---------------------------------------------------------------------------\r\nImportError                               Traceback (most recent call last)\r\n<ipython-input-1-0484cd13f94d> in <module>\r\n----> 1 import matplotlib\r\n\r\nc:\\users\\nzlab\\envs\\nta-1465\\lib\\site-packages\\matplotlib\\__init__.py in <module>\r\n    172\r\n    173\r\n--> 174 _check_versions()\r\n    175\r\n    176\r\n\r\nc:\\users\\nzlab\\envs\\nta-1465\\lib\\site-packages\\matplotlib\\__init__.py in _check_versions()\r\n    157     # Quickfix to ensure Microsoft Visual C++ redistributable\r\n    158     # DLLs are loaded before importing kiwisolver\r\n--> 159     from . import ft2font\r\n    160\r\n    161     for modname, minver in [\r\n\r\nImportError: DLL load failed: The specified module could not be found.\r\n\r\n```\r\n\r\n**Expected outcome**\r\n\r\n<!--A description of the expected outcome from the code snippet-->\r\n<!--If this used to work in an earlier version of Matplotlib, please note the version it used to work on-->\r\n\r\nNo error should be presented. \r\n\r\n**Matplotlib version**\r\n<!--Please specify your platform and versions of the relevant libraries you are using:-->\r\n  * Operating system: Windows 7 (64bit), Windows 10 (64bit)\r\n  * Matplotlib version: 3.3.1\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: Python 3.7.6\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: Microsoft Visual C++ 2015-2019 Redistributable (x64) - 14.27.29016 **NOT INSTALLED**\r\n\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\r\n\r\n**Further diagnose shows: **\r\n\r\n- ft2font.cp37-win_amd64.pyd (Matplotlib 3.3.0) links VCRUNTIME140.dll\r\n- ft2font.cp37-win_amd64.pyd (Matplotlib 3.3.1) links VCRUNTIME140_1.dll\r\n\r\nThose computers which have DLL load failed don't have VCRUNTIME140_1.dll in DLL search path. \r\n\r\n**Solution**\r\nInstalling the latest [Visual Studio 2015, 2019 and 2019 redistributable](https://support.microsoft.com/en-nz/help/2977003/the-latest-supported-visual-c-downloads) should address the issue. \r\n\r\n**Question**\r\nIs changing in VC++ API (from 14 to 14.1) an intentional move on Matplotlib 3.3.1 for Windows release? If so, should the VC++ dependency to be added to Installation Guide? ",
        "issue_id": 18292,
        "pr_number": 18322,
        "pr_title": "Disable FH4 so that we don't require VCRUNTIME140_1.dll.",
        "pr_body": "## PR Summary\r\n\r\nFor more details, see:\r\nhttps://devblogs.microsoft.com/cppblog/making-cpp-exception-handling-smaller-x64/\r\nhttps://github.com/joerick/cibuildwheel/issues/423#issuecomment-677763904\r\n\r\nFixes #18292.\r\n\r\n## PR Checklist\r\n\r\n- [n/a] Has Pytest style unit tests\r\n- [n/a] Code is [Flake 8](http://flake8.pycqa.org/en/latest/) compliant\r\n- [n/a] New features are documented, with examples if plot related\r\n- [n/a] Documentation is sphinx and numpydoc compliant\r\n- [n/a] Added an entry to doc/users/next_whats_new/ if major new feature (follow instructions in README.rst there)\r\n- [n/a] Documented in doc/api/next_api_changes/* if API changed in a backward-incompatible way",
        "issue_closed_at": "2020-08-24T00:49:39Z",
        "base_commit": "5102676244c24622639601b693c552dad0b6259e"
      },
      "summary": "### Summary:\nThis issue is a compatibility problem encountered when upgrading software libraries, specifically Matplotlib, on certain Windows operating systems. The problem manifests as an `ImportError` related to the inability to load a Dynamic Link Library (DLL) when importing the Matplotlib library. This error arises due to a missing dependency on a specific version of the Microsoft Visual C++ runtime library, which was not included in the search path of affected systems. The issue is triggered when the `ft2font` module of Matplotlib attempts to load, leading to a failure in running any code that imports Matplotlib.\n\nKey symptoms include the `ImportError` message citing that a module could not be found, specifically the `ft2font` module, when executing an import statement for Matplotlib. The affected systems are Windows 7 and Windows 10, both 64-bit versions, which lack the required `VCRUNTIME140_1.dll`. The problem specifically impacts users who upgraded from Matplotlib version 3.3.0 to 3.3.1 without ensuring the necessary runtime components are installed.\n\nThe potential impact is significant for users relying on Matplotlib for data visualization, as the inability to import the library prevents any further usage of its features. This could disrupt workflows, particularly in environments where Matplotlib is a critical tool for data analysis or presentation.\n\nTechnically, the issue stems from a dependency change in the Matplotlib library, where the `ft2font` module in version 3.3.1 links to a newer version of the Microsoft Visual C++ runtime than previous versions. This dependency alteration was not clearly communicated, leading to confusion and errors for users who had not pre-installed the required runtime libraries. The recommended solution is to install the latest Visual Studio redistributable package, which resolves the missing DLL issue and restores functionality.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: ImportError: DLL load failed with Matplotlib 3.3.1 on Windows\n\nBody:\n<!--To help us understand and resolve your issue, please fill out the form to the best of your ability.-->\r\n<!--You can feel free to delete the sections that do not apply.-->\r\n\r\n### Bug report\r\n\r\n**Bug summary**\r\n\r\nOn some Windows machines (including Windows 10 and Windows 7), we experienced `ImportError: DLL load failed: The specific module could not be found` after upgrading from Matplotlib 3.3.0 to 3.3.1. \r\n\r\n**Code for reproduction**\r\n\r\n`import matplotlib` would trigger the import error while trying to import ft2font.\r\n\r\n\r\n**Actual outcome**\r\n\r\n```python\r\nIn [1]: import matplotlib\r\n---------------------------------------------------------------------------\r\nImportError                               Traceback (most recent call last)\r\n<ipython-input-1-0484cd13f94d> in <module>\r\n----> 1 import matplotlib\r\n\r\nc:\\users\\nzlab\\envs\\nta-1465\\lib\\site-packages\\matplotlib\\__init__.py in <module>\r\n    172\r\n    173\r\n--> 174 _check_versions()\r\n    175\r\n    176\r\n\r\nc:\\users\\nzlab\\envs\\nta-1465\\lib\\site-packages\\matplotlib\\__init__.py in _check_versions()\r\n    157     # Quickfix to ensure Microsoft Visual C++ redistributable\r\n    158     # DLLs are loaded before importing kiwisolver\r\n--> 159     from . import ft2font\r\n    160\r\n    161     for modname, minver in [\r\n\r\nImportError: DLL load failed: The specified module could not be found.\r\n\r\n```\r\n\r\n**Expected outcome**\r\n\r\n<!--A description of the expected outcome from the code snippet-->\r\n<!--If this used to work in an earlier version of Matplotlib, please note the version it used to work on-->\r\n\r\nNo error should be presented. \r\n\r\n**Matplotlib version**\r\n<!--Please specify your platform and versions of the relevant libraries you are using:-->\r\n  * Operating system: Windows 7 (64bit), Windows 10 (64bit)\r\n  * Matplotlib version: 3.3.1\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: Python 3.7.6\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: Microsoft Visual C++ 2015-2019 Redistributable (x64) - 14.27.29016 **NOT INSTALLED**\r\n\r\n<!--Please tell us how you installed matplotlib and python e.g., from source, pip, conda-->\r\n<!--If you installed from conda, please specify which channel you used if not the default-->\r\n\r\n**Further diagnose shows: **\r\n\r\n- ft2font.cp37-win_amd64.pyd (Matplotlib 3.3.0) links VCRUNTIME140.dll\r\n- ft2font.cp37-win_amd64.pyd (Matplotlib 3.3.1) links VCRUNTIME140_1.dll\r\n\r\nThose computers which have DLL load failed don't have VCRUNTIME140_1.dll in DLL search path. \r\n\r\n**Solution**\r\nInstalling the latest [Visual Studio 2015, 2019 and 2019 redistributable](https://support.microsoft.com/en-nz/help/2977003/the-latest-supported-visual-c-downloads) should address the issue. \r\n\r\n**Question**\r\nIs changing in VC++ API (from 14 to 14.1) an intentional move on Matplotlib 3.3.1 for Windows release? If so, should the VC++ dependency to be added to Installation Guide? \n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nsetup.py\n  function: BuildExtraLibraries.build_extensions\n"
    },
    {
      "similar_issue": {
        "issue_title": "Colorbar for imshow messes interactive cursor with masked data",
        "issue_body": "### Bug report\r\n\r\nAdding a colorbar when the mappable is the result of imshow for a masked array changes the behavior of the interactive z-data cursor and triggers a UserWarning.\r\n\r\n**Code for reproduction**\r\n```python\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\n\r\nmask = np.zeros((4, 4), bool)\r\nmask[:2] = True\r\nA = np.ma.array(np.random.rand(4, 4), mask=mask)\r\n\r\nfig, ax = plt.subplots(1, 1)\r\nim = ax.imshow(A)\r\nfig.colorbar(im)\r\n```\r\n\r\n**Actual outcome**\r\n```\r\n~/.anaconda3/lib/python3.7/site-packages/matplotlib/ticker.py:632: UserWarning: Warning: converting a masked element to nan.\r\n  return '%-12g' % value\r\n```\r\n![Screenshot from 2019-08-22 18-22-23](https://user-images.githubusercontent.com/52320542/63531938-e9d5ef00-c509-11e9-83ef-7ce9bc3f3c59.png)\r\n\r\n**Expected outcome**\r\nBefore adding the colorbar, the zdata cursor shows a blank (`[]`).\r\n\r\n**Matplotlib version**\r\n  * Operating system: Linux\r\n  * Matplotlib version: 3.1.1\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.7.3\r\n  * IPython version: 7.2.0\r\n  * Other libraries: \r\nMatplotlib installed from pip.\r\n\r\n\r\n\r\n",
        "issue_id": 15103,
        "pr_number": 15140,
        "pr_title": "Fix ScalarFormatter formatting of masked values",
        "pr_body": "Fixes #15103. Could probably do with a test. Possibly an API change since previously a masked value would be formatted as `nan`?",
        "issue_closed_at": "2019-08-28T03:46:25Z",
        "base_commit": "40dfc353aa66b93fd0fbc55ca1f51701202c0549"
      },
      "summary": "### Summary:\n\nThis issue is related to the interaction between the `imshow` function and the `colorbar` in Matplotlib when handling masked arrays. It specifically affects the behavior of the interactive cursor that displays z-data, leading to unexpected warnings and display issues. \n\n1. **Problem Description in General Terms:** The addition of a colorbar to a plot created with `imshow` for masked arrays alters the expected behavior of interactive features and generates unnecessary warnings. This problem arises when masked data is involved, leading to difficulties in data visualization and analysis.\n\n2. **Key Symptoms and Behaviors Observed:** Users encounter a `UserWarning` regarding the conversion of masked elements to NaN values when a colorbar is added. Moreover, the interactive z-data cursor's behavior is inconsistent, showing unexpected values or warnings instead of the anticipated blank output.\n\n3. **Affected Components or Systems:** The issue primarily affects the Matplotlib library, particularly the `imshow` function, the colorbar component, and the interactive features reliant on data cursors. It is evident in environments using Matplotlib version 3.1.1 with the Qt5Agg backend on a Linux system.\n\n4. **Potential Impact or Severity:** This issue can be significant for users relying on interactive data visualization for masked arrays, as it disrupts the visual representation and interpretation of data. The severity is compounded in environments where precise data visualization is crucial, such as in scientific research and data analysis.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:** The root cause involves the interaction between masked arrays and plotting functions that expect complete datasets. When a colorbar is added, the conversion of masked values to NaNs triggers warnings and affects the interactive display. The problem highlights the need for improved handling of masked data in visualization tools to ensure robust and error-free outputs.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Colorbar for imshow messes interactive cursor with masked data\n\nBody:\n### Bug report\r\n\r\nAdding a colorbar when the mappable is the result of imshow for a masked array changes the behavior of the interactive z-data cursor and triggers a UserWarning.\r\n\r\n**Code for reproduction**\r\n```python\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\n\r\nmask = np.zeros((4, 4), bool)\r\nmask[:2] = True\r\nA = np.ma.array(np.random.rand(4, 4), mask=mask)\r\n\r\nfig, ax = plt.subplots(1, 1)\r\nim = ax.imshow(A)\r\nfig.colorbar(im)\r\n```\r\n\r\n**Actual outcome**\r\n```\r\n~/.anaconda3/lib/python3.7/site-packages/matplotlib/ticker.py:632: UserWarning: Warning: converting a masked element to nan.\r\n  return '%-12g' % value\r\n```\r\n![Screenshot from 2019-08-22 18-22-23](https://user-images.githubusercontent.com/52320542/63531938-e9d5ef00-c509-11e9-83ef-7ce9bc3f3c59.png)\r\n\r\n**Expected outcome**\r\nBefore adding the colorbar, the zdata cursor shows a blank (`[]`).\r\n\r\n**Matplotlib version**\r\n  * Operating system: Linux\r\n  * Matplotlib version: 3.1.1\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.7.3\r\n  * IPython version: 7.2.0\r\n  * Other libraries: \r\nMatplotlib installed from pip.\r\n\r\n\r\n\r\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/ticker.py\n  function: LogitFormatter.format_data_short\n"
    },
    {
      "similar_issue": {
        "issue_title": "Colorbar outline has broken path in vector backends",
        "issue_body": "Hi again,\nIn all of the vector graphics backends that I tested (pdf, eps, ps, svg), the colorbar outline is drawn with a broken path at the corner where the path starts and ends.  This does not happen with the raster graphic or interactive backends.  Here is a minimal working example:\n\n``` python\nimport numpy as np\nimport matplotlib as mpl\nimport matplotlib.pyplot as plt\n\nmpl.rcParams.update({'axes.linewidth':10})\n\nfig = plt.figure(figsize=(8,6))\nax1 = fig.add_axes([0.05, 0.85, 0.9, 0.1])\nax2 = fig.add_axes([0.05, 0.65, 0.9, 0.1])\nax3 = fig.add_axes([0.05, 0.45, 0.9, 0.1])\nax4 = fig.add_axes([0.05, 0.25, 0.9, 0.1])\nax5 = fig.add_axes([0.05, 0.05, 0.9, 0.1])\n\ncmap = mpl.cm.jet\ncmap.set_under('w')\ncmap.set_over('w')\n\nim = ax1.pcolormesh(np.linspace(0,10,16).reshape((4,4)))\n\nplt.colorbar(im,cax=ax2,cmap=cmap,orientation='horizontal',\n             extend='both',extendfrac=0.5)\nplt.colorbar(im,cax=ax3,cmap=cmap,orientation='horizontal',\n             extend='both',)\nplt.colorbar(im,cax=ax4,cmap=cmap,orientation='horizontal',\n             extend='both',extendrect=True)\nplt.colorbar(im,cax=ax5,cmap=cmap,orientation='horizontal',\n             extend='neither')\n\nplt.savefig('colorbar_tip.pdf')\nplt.savefig('colorbar_tip.eps')\nplt.savefig('colorbar_tip.svg')\n```\n\nTested with matplotlib 1.4.3, and python 2.7, on Linux and Windows. I have exaggerated the axes linewidth to make the problem more visible.  Here is a screenshot of the PDF output:\n\n![colorbar_tip](https://cloud.githubusercontent.com/assets/8595627/6471312/c556da04-c1b7-11e4-8711-25ba893eb043.png)\n\nI have been able to fix this by making the following change to the `ColorbarBase` class in colorbar.py:\n\n``` python\ndef _config_axes(self, X, Y):\n\n    ...\n\n    if self.outline is not None:\n        self.outline.remove()\n\n    xy2 = np.append(xy,xy[1:2,:],axis=0) # <-- added\n\n    self.outline = mpatches.Polygon(\n        xy2, edgecolor=mpl.rcParams['axes.edgecolor'], # <-- modified\n        facecolor='none',\n        linewidth=mpl.rcParams['axes.linewidth'],\n        closed=True,\n        zorder=2)\n\n    ...\n```\n\nThis essentially just copies the second point of the path to the end of the path.  However, I don't know if this is the best fix.  I don't know anything about vector graphics drawing directives, but it seems to me that there should be a builtin function to have paths wrap-around enough so that it creates a closed loop, including drawing the correct corner.  Clearly the `closed=True` option of the `mpatches.Polygon` is not doing this.\n\nAgain, thanks to anyone who looks into this.\n",
        "issue_id": 4185,
        "pr_number": 4186,
        "pr_title": "Close clipped paths",
        "pr_body": "Fix #4185.\n",
        "issue_closed_at": "2015-03-04T22:48:51Z",
        "base_commit": "6387fcaaeeff4777373429a54d79ca270cbd2522"
      },
      "summary": "### Summary:\nThis issue is related to the rendering of colorbar outlines in vector graphics backends, such as PDF, EPS, PS, and SVG, where the outlines appear broken at the corner where the path starts and ends. This problem does not affect raster or interactive backends. The issue is particularly noticeable when the axes linewidth is exaggerated, as demonstrated in the provided minimal working example using Matplotlib 1.4.3 and Python 2.7 on Linux and Windows platforms. The colorbar outlines fail to close properly, resulting in a visible break. The issue was addressed by modifying the `ColorbarBase` class in the `colorbar.py` file, specifically by appending the second point of the path to the end of the path to ensure a closed loop. This fix suggests the need for improved handling of path closure in vector graphics rendering, as the existing `closed=True` option in the `mpatches.Polygon` function does not adequately resolve the issue. The affected components include various parts of the Matplotlib library related to vector graphics rendering, including functions in `backend_ps.py` and `backend_svg.py`. The problem impacts the visual integrity of vector graphics outputs, potentially compromising the quality of figures intended for publication or presentation.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Colorbar outline has broken path in vector backends\n\nBody:\nHi again,\nIn all of the vector graphics backends that I tested (pdf, eps, ps, svg), the colorbar outline is drawn with a broken path at the corner where the path starts and ends.  This does not happen with the raster graphic or interactive backends.  Here is a minimal working example:\n\n``` python\nimport numpy as np\nimport matplotlib as mpl\nimport matplotlib.pyplot as plt\n\nmpl.rcParams.update({'axes.linewidth':10})\n\nfig = plt.figure(figsize=(8,6))\nax1 = fig.add_axes([0.05, 0.85, 0.9, 0.1])\nax2 = fig.add_axes([0.05, 0.65, 0.9, 0.1])\nax3 = fig.add_axes([0.05, 0.45, 0.9, 0.1])\nax4 = fig.add_axes([0.05, 0.25, 0.9, 0.1])\nax5 = fig.add_axes([0.05, 0.05, 0.9, 0.1])\n\ncmap = mpl.cm.jet\ncmap.set_under('w')\ncmap.set_over('w')\n\nim = ax1.pcolormesh(np.linspace(0,10,16).reshape((4,4)))\n\nplt.colorbar(im,cax=ax2,cmap=cmap,orientation='horizontal',\n             extend='both',extendfrac=0.5)\nplt.colorbar(im,cax=ax3,cmap=cmap,orientation='horizontal',\n             extend='both',)\nplt.colorbar(im,cax=ax4,cmap=cmap,orientation='horizontal',\n             extend='both',extendrect=True)\nplt.colorbar(im,cax=ax5,cmap=cmap,orientation='horizontal',\n             extend='neither')\n\nplt.savefig('colorbar_tip.pdf')\nplt.savefig('colorbar_tip.eps')\nplt.savefig('colorbar_tip.svg')\n```\n\nTested with matplotlib 1.4.3, and python 2.7, on Linux and Windows. I have exaggerated the axes linewidth to make the problem more visible.  Here is a screenshot of the PDF output:\n\n![colorbar_tip](https://cloud.githubusercontent.com/assets/8595627/6471312/c556da04-c1b7-11e4-8711-25ba893eb043.png)\n\nI have been able to fix this by making the following change to the `ColorbarBase` class in colorbar.py:\n\n``` python\ndef _config_axes(self, X, Y):\n\n    ...\n\n    if self.outline is not None:\n        self.outline.remove()\n\n    xy2 = np.append(xy,xy[1:2,:],axis=0) # <-- added\n\n    self.outline = mpatches.Polygon(\n        xy2, edgecolor=mpl.rcParams['axes.edgecolor'], # <-- modified\n        facecolor='none',\n        linewidth=mpl.rcParams['axes.linewidth'],\n        closed=True,\n        zorder=2)\n\n    ...\n```\n\nThis essentially just copies the second point of the path to the end of the path.  However, I don't know if this is the best fix.  I don't know anything about vector graphics drawing directives, but it seems to me that there should be a builtin function to have paths wrap-around enough so that it creates a closed loop, including drawing the correct corner.  Clearly the `closed=True` option of the `mpatches.Polygon` is not doing this.\n\nAgain, thanks to anyone who looks into this.\n\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\nlib/matplotlib/backends/backend_ps.py\n  function: print_figure_impl\n  function: NullWriter.write\n\nlib/matplotlib/backends/backend_svg.py\n  function: RendererSVG._write_default_style\n"
    }
  ]
}