{
  "instance_id": "matplotlib__matplotlib-23476",
  "repo": "matplotlib/matplotlib",
  "created_at": "2022-07-22T18:58:22Z",
  "problem_statement": "[Bug]: DPI of a figure is doubled after unpickling on M1 Mac\n### Bug summary\r\n\r\nWhen a figure is unpickled, it's dpi is doubled. This behaviour happens every time and if done in a loop it can cause an `OverflowError`.\r\n\r\n### Code for reproduction\r\n\r\n```python\r\nimport numpy as np\r\nimport matplotlib\r\nimport matplotlib.pyplot as plt\r\nimport pickle\r\nimport platform\r\n\r\nprint(matplotlib.get_backend())\r\nprint('Matplotlib ver:', matplotlib.__version__)\r\nprint('Platform:', platform.platform())\r\nprint('System:', platform.system())\r\nprint('Release:', platform.release())\r\nprint('Python ver:', platform.python_version())\r\n\r\n\r\ndef dump_load_get_dpi(fig):\r\n    with open('sinus.pickle','wb') as file:\r\n        pickle.dump(fig, file)\r\n\r\n    with open('sinus.pickle', 'rb') as blob:\r\n        fig2 = pickle.load(blob)\r\n    return fig2, fig2.dpi\r\n\r\n\r\ndef run():\r\n    fig = plt.figure()\r\n    x = np.linspace(0,2*np.pi)\r\n    y = np.sin(x)\r\n\r\n    for i in range(32):\r\n        print(f'{i}: {fig.dpi}')\r\n        fig, dpi = dump_load_get_dpi(fig)\r\n\r\n\r\nif __name__ == '__main__':\r\n    run()\r\n```\r\n\r\n\r\n### Actual outcome\r\n\r\n```\r\nMacOSX\r\nMatplotlib ver: 3.5.2\r\nPlatform: macOS-12.4-arm64-arm-64bit\r\nSystem: Darwin\r\nRelease: 21.5.0\r\nPython ver: 3.9.12\r\n0: 200.0\r\n1: 400.0\r\n2: 800.0\r\n3: 1600.0\r\n4: 3200.0\r\n5: 6400.0\r\n6: 12800.0\r\n7: 25600.0\r\n8: 51200.0\r\n9: 102400.0\r\n10: 204800.0\r\n11: 409600.0\r\n12: 819200.0\r\n13: 1638400.0\r\n14: 3276800.0\r\n15: 6553600.0\r\n16: 13107200.0\r\n17: 26214400.0\r\n18: 52428800.0\r\n19: 104857600.0\r\n20: 209715200.0\r\n21: 419430400.0\r\nTraceback (most recent call last):\r\n  File \"/Users/wsykala/projects/matplotlib/example.py\", line 34, in <module>\r\n    run()\r\n  File \"/Users/wsykala/projects/matplotlib/example.py\", line 30, in run\r\n    fig, dpi = dump_load_get_dpi(fig)\r\n  File \"/Users/wsykala/projects/matplotlib/example.py\", line 20, in dump_load_get_dpi\r\n    fig2 = pickle.load(blob)\r\n  File \"/Users/wsykala/miniconda3/envs/playground/lib/python3.9/site-packages/matplotlib/figure.py\", line 2911, in __setstate__\r\n    mgr = plt._backend_mod.new_figure_manager_given_figure(num, self)\r\n  File \"/Users/wsykala/miniconda3/envs/playground/lib/python3.9/site-packages/matplotlib/backend_bases.py\", line 3499, in new_figure_manager_given_figure\r\n    canvas = cls.FigureCanvas(figure)\r\n  File \"/Users/wsykala/miniconda3/envs/playground/lib/python3.9/site-packages/matplotlib/backends/backend_macosx.py\", line 32, in __init__\r\n    _macosx.FigureCanvas.__init__(self, width, height)\r\nOverflowError: signed integer is greater than maximum\r\n```\r\n\r\n### Expected outcome\r\n\r\n```\r\nMacOSX\r\nMatplotlib ver: 3.5.2\r\nPlatform: macOS-12.4-arm64-arm-64bit\r\nSystem: Darwin\r\nRelease: 21.5.0\r\nPython ver: 3.9.12\r\n0: 200.0\r\n1: 200.0\r\n2: 200.0\r\n3: 200.0\r\n4: 200.0\r\n5: 200.0\r\n6: 200.0\r\n7: 200.0\r\n8: 200.0\r\n9: 200.0\r\n10: 200.0\r\n11: 200.0\r\n12: 200.0\r\n13: 200.0\r\n14: 200.0\r\n15: 200.0\r\n16: 200.0\r\n17: 200.0\r\n18: 200.0\r\n19: 200.0\r\n20: 200.0\r\n21: 200.0\r\n22: 200.0\r\n```\r\n\r\n### Additional information\r\n\r\nThis seems to happen only on M1 MacBooks and the version of python doesn't matter.\r\n\r\n### Operating system\r\n\r\nOS/X\r\n\r\n### Matplotlib Version\r\n\r\n3.5.2\r\n\r\n### Matplotlib Backend\r\n\r\nMacOSX\r\n\r\n### Python version\r\n\r\n3.9.12\r\n\r\n### Jupyter version\r\n\r\n_No response_\r\n\r\n### Installation\r\n\r\npip\n",
  "patch": "diff --git a/lib/matplotlib/figure.py b/lib/matplotlib/figure.py\n--- a/lib/matplotlib/figure.py\n+++ b/lib/matplotlib/figure.py\n@@ -3023,6 +3023,9 @@ def __getstate__(self):\n         # Set cached renderer to None -- it can't be pickled.\n         state[\"_cachedRenderer\"] = None\n \n+        # discard any changes to the dpi due to pixel ratio changes\n+        state[\"_dpi\"] = state.get('_original_dpi', state['_dpi'])\n+\n         # add version information to the state\n         state['__mpl_version__'] = mpl.__version__\n \n",
  "similar_bug_items": [
    {
      "pr_number": 11165,
      "pr_title": "Fix figure window icon",
      "pr_body": "## PR Summary\r\nFixes #11138 \r\n\r\n## PR Checklist\r\n\r\n- [x] Has Pytest style unit tests\r\n- [x] Code is PEP 8 compliant\r\n- [x] New features are documented, with examples if plot related\r\n- [x] 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",
      "issue_id": 11138,
      "issue_title": "Only the first figure window has mpl icon, all other figures have default tk icon.",
      "issue_body": "### Bug report\r\n\r\n**Bug summary**\r\nWhen plot more than one figure window, only the first figure window has the default mpl icon (come from matplotlib.ppm), and all other figure windows' icon is set to the default tk icon.\r\n\r\n**Code for reproduction**\r\n\r\ncode 1:\r\n```python\r\nimport logging\r\nimport matplotlib.pyplot as plt\r\nlogging.basicConfig(format=\"%(name)s %(levelname)s: %(message)s\", level=logging.INFO)\r\nplt.figure(1)\r\nplt.plot([1,2,3])\r\nplt.show()\r\n```\r\n\r\ncode 2:\r\n```python\r\nimport logging\r\nimport matplotlib.pyplot as plt\r\nlogging.basicConfig(format=\"%(name)s %(levelname)s: %(message)s\", level=logging.INFO)\r\nplt.figure(1)\r\nplt.plot([1,2,3])\r\nplt.figure(2)\r\nplt.plot([4,5,6])\r\nplt.show()\r\n```\r\n\r\ncode 3:\r\n```python\r\nimport logging\r\nimport matplotlib.pyplot as plt\r\nlogging.basicConfig(format=\"%(name)s %(levelname)s: %(message)s\", level=logging.INFO)\r\nplt.figure(1)\r\nplt.plot([1,2,3])\r\nplt.figure(2)\r\nplt.plot([4,5,6])\r\nplt.figure(3)\r\nplt.plot([7,8,9])\r\nplt.show()\r\n```\r\n\r\n**Actual outcome**\r\ncode 1 runs normally.\r\n\r\ncode 2 will log:\r\n```\r\nmatplotlib.backends._backend_tk INFO: Could not load matplotlib icon: can't use \"pyimage10\" as iconphoto: not a photo image\r\n```\r\nAnd the icon of figure 1 and figure 2 is different.\r\n\r\ncode 3 will log:\r\n```\r\nmatplotlib.backends._backend_tk INFO: Could not load matplotlib icon: can't use \"pyimage10\" as iconphoto: not a photo image\r\nmatplotlib.backends._backend_tk INFO: Could not load matplotlib icon: can't use \"pyimage19\" as iconphoto: not a photo image\r\n```\r\nThe icon of figure 1 is different than figure 2 and 3.\r\nScreenshot attached:\r\nIcon of window:\r\n![figure_title](https://user-images.githubusercontent.com/35422407/39393621-04eec34c-4afa-11e8-85a0-6f4aa58f8c4c.png)\r\n\r\nAnd the icon in taskbar:\r\n![taskbar](https://user-images.githubusercontent.com/35422407/39393623-0ad91244-4afa-11e8-8536-49138602fb4e.png)\r\n\r\nIf debug, the log information is coming from the exception:\r\n```\r\nfile: matplotlib/backends/_backend_tk.py\r\nclass _BackendTk()\r\nmethod new_figure_manager_given_figure()\r\n        # Put a mpl icon on the window rather than the default tk icon.\r\n        # Tkinter doesn't allow colour icons on linux systems, but tk>=8.5 has\r\n        # a iconphoto command which we call directly. Source:\r\n        # http://mail.python.org/pipermail/tkinter-discuss/2006-November/000954.html\r\n        icon_fname = os.path.join(\r\n            rcParams['datapath'], 'images', 'matplotlib.ppm')\r\n        icon_img = Tk.PhotoImage(file=icon_fname)\r\n        try:\r\n            window.tk.call('wm', 'iconphoto', window._w, icon_img)\r\n        except Exception as exc:\r\n            # log the failure (due e.g. to Tk version), but carry on\r\n            _log.info('Could not load matplotlib icon: %s', exc)\r\n```\r\n\r\n**Expected outcome**\r\nAll figure's icon are same by default.\r\n\r\n**Matplotlib version**\r\n  * Operating system: Windows 7 pro.\r\n  * Matplotlib version:  2.2.2\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): TkAgg\r\n  * Python version: 3.6.5\r\n\r\n",
      "issue_closed_at": "2018-07-08T17:50:21Z",
      "base_commit": "c20b0c2bede5e354ac3bc90858d247c2a2d10d5e",
      "changes": [
        {
          "file": "lib/matplotlib/backends/_backend_tk.py",
          "type": "function",
          "name": "new_figure_manager_given_figure",
          "class_name": "_BackendTk",
          "code": "def new_figure_manager_given_figure(cls, num, figure):\n        \"\"\"\n        Create a new figure manager instance for the given figure.\n        \"\"\"\n        with _restore_foreground_window_at_end():\n            window = Tk.Tk(className=\"matplotlib\")\n            window.withdraw()\n\n            # Put a mpl icon on the window rather than the default tk icon.\n            # Tkinter doesn't allow colour icons on linux systems, but tk>=8.5 has\n            # a iconphoto command which we call directly. Source:\n            # http://mail.python.org/pipermail/tkinter-discuss/2006-November/000954.html\n            icon_fname = os.path.join(\n                rcParams['datapath'], 'images', 'matplotlib.ppm')\n            icon_img = Tk.PhotoImage(file=icon_fname)\n            try:\n                window.tk.call('wm', 'iconphoto', window._w, icon_img)\n            except Exception as exc:\n                # log the failure (due e.g. to Tk version), but carry on\n                _log.info('Could not load matplotlib icon: %s', exc)\n\n            canvas = cls.FigureCanvas(figure, master=window)\n            manager = cls.FigureManager(canvas, num, window)\n            if matplotlib.is_interactive():\n                manager.show()\n                canvas.draw_idle()\n            return manager"
        }
      ]
    },
    {
      "pr_number": 9661,
      "pr_title": "Fix arcs with very large width/height.",
      "pr_body": "## PR Summary\r\n\r\nLarge width/height triggers a different code path that didn't correctly\r\ndraw limited arcs instead of the whole ellipse.\r\n\r\nFixes #9659.\r\n\r\n## PR Checklist\r\n\r\n- [x] Has Pytest style unit tests\r\n- [x] Code is PEP 8 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/api_changes.rst if API changed in a backward-incompatible way",
      "issue_id": 9659,
      "issue_title": "patches.Arc objects randomly drawing the full ellipse",
      "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\nProviding theta1 and theta2 to the Arc constructor sometimes causes the arc to be drawn as the full ellipse.\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug, also minimizing the number of dependencies required-->\r\n\r\n```python\r\nfrom matplotlib.patches import Arc\r\nimport matplotlib.pyplot as plt\r\n\r\npatches = [\r\n    Arc((143954140, 374), 476, 476, theta1=0, theta2=180),\r\n    Arc((143954902, 374), 2001, 749, theta1=0, theta2=180),\r\n    Arc((143955137, 374), 2471, 749, theta1=0, theta2=180),\r\n    Arc((143955276, 374), 2748, 749, theta1=0, theta2=180),\r\n    Arc((143955362, 374), 2022, 749, theta1=0, theta2=180),\r\n    Arc((143955500, 374), 2299, 749, theta1=0, theta2=180),\r\n    Arc((143955641, 374), 488, 488, theta1=0, theta2=180),\r\n    Arc((143955650, 374), 506, 506, theta1=0, theta2=180),\r\n    Arc((143955885, 374), 976, 749, theta1=0, theta2=180),\r\n    Arc((143956128, 374), 489, 489, theta1=0, theta2=180),\r\n    Arc((143956135, 374), 467, 467, theta1=0, theta2=180),\r\n    Arc((143956137, 374), 471, 471, theta1=0, theta2=180),\r\n    Arc((143956276, 374), 748, 748, theta1=0, theta2=180),\r\n    Arc((143956515, 374), 1226, 749, theta1=0, theta2=180),\r\n    Arc((143956167, 374), 412, 412, theta1=0, theta2=180),\r\n    Arc((143956170, 374), 402, 402, theta1=0, theta2=180),\r\n    Arc((143956172, 374), 401, 401, theta1=0, theta2=180),\r\n    Arc((143956183, 374), 380, 380, theta1=0, theta2=180),\r\n    Arc((143956321, 374), 657, 657, theta1=0, theta2=180),\r\n    Arc((143956610, 374), 80, 80, theta1=0, theta2=180),\r\n    Arc((143956849, 374), 558, 558, theta1=0, theta2=180),\r\n    Arc((143956928, 374), 400, 400, theta1=0, theta2=180),\r\n    Arc((143956960, 374), 335, 335, theta1=0, theta2=180),\r\n    Arc((143956962, 374), 331, 331, theta1=0, theta2=180),\r\n    Arc((143957055, 374), 146, 146, theta1=0, theta2=180),\r\n    Arc((143957346, 374), 105, 105, theta1=0, theta2=180),\r\n    Arc((143957397, 374), 207, 207, theta1=0, theta2=180),\r\n    Arc((143957448, 374), 308, 308, theta1=0, theta2=180),\r\n    Arc((143957459, 374), 331, 331, theta1=0, theta2=180),\r\n    Arc((143957475, 374), 363, 363, theta1=0, theta2=180),\r\n    Arc((143957696, 374), 804, 749, theta1=0, theta2=180),\r\n    Arc((143958871, 374), 3154, 749, theta1=0, theta2=180),\r\n    Arc((143957954, 374), 287, 287, theta1=0, theta2=180),\r\n    Arc((143957957, 374), 292, 292, theta1=0, theta2=180),\r\n    Arc((143958125, 374), 628, 628, theta1=0, theta2=180),\r\n    Arc((143958305, 374), 268, 268, theta1=0, theta2=180),\r\n    Arc((143958313, 374), 251, 251, theta1=0, theta2=180),\r\n    Arc((143958368, 374), 142, 142, theta1=0, theta2=180),\r\n    Arc((143958369, 374), 136, 136, theta1=0, theta2=180),\r\n    Arc((143958370, 374), 138, 138, theta1=0, theta2=180),\r\n    Arc((143958905, 374), 535, 535, theta1=0, theta2=180),\r\n    Arc((143959528, 374), 1780, 749, theta1=0, theta2=180),\r\n    Arc((143959543, 374), 1810, 749, theta1=0, theta2=180),\r\n    Arc((143959544, 374), 1813, 749, theta1=0, theta2=180),\r\n    Arc((143959849, 374), 1198, 749, theta1=0, theta2=180),\r\n    Arc((143960119, 374), 658, 658, theta1=0, theta2=180),\r\n    Arc((143960678, 374), 151, 151, theta1=0, theta2=180),\r\n    Arc((143960682, 374), 158, 158, theta1=0, theta2=180),\r\n    Arc((143960682, 374), 159, 159, theta1=0, theta2=180),\r\n    Arc((143960723, 374), 241, 241, theta1=0, theta2=180),\r\n    Arc((143960797, 374), 388, 388, theta1=0, theta2=180),\r\n    Arc((143960845, 374), 484, 484, theta1=0, theta2=180),\r\n    Arc((143960809, 374), 363, 363, theta1=0, theta2=180),\r\n    Arc((143960943, 374), 95, 95, theta1=0, theta2=180),\r\n    Arc((143960945, 374), 92, 92, theta1=0, theta2=180)\r\n]\r\n\r\nplt.figure()\r\nax = plt.gca()\r\nmap(ax.add_patch, patches)\r\nplt.xlim(143953697, 143961337)\r\nplt.ylim(-150, 900)\r\nplt.show()\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n![image](https://user-images.githubusercontent.com/17572426/32301746-967dedf2-bf35-11e7-8263-102883c3a99a.png)\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\nAll the arcs should be half-ellipses above the line `y = 0.5`.\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: Mac OS Sierra\r\n  * Matplotlib version: 2.1.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): MacOSX\r\n  * Python version: 2.7.14 (Homebrew)\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: numpy 13.3.3\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\npython 2.7.14 from homebrew (`brew install python`); matplotlib from pip (`sudo -H pip install matplotlib`)\r\n",
      "issue_closed_at": "2017-11-02T10:07:32Z",
      "base_commit": "c46599356379b148afe331ad8bc05fb343cf7e85",
      "changes": [
        {
          "file": "lib/matplotlib/patches.py",
          "type": "function",
          "name": "iter_circle_intersect_on_line_seg",
          "class_name": "Arc",
          "code": "def iter_circle_intersect_on_line_seg(x0, y0, x1, y1):\n            epsilon = 1e-9\n            if x1 < x0:\n                x0e, x1e = x1, x0\n            else:\n                x0e, x1e = x0, x1\n            if y1 < y0:\n                y0e, y1e = y1, y0\n            else:\n                y0e, y1e = y0, y1\n            x0e -= epsilon\n            y0e -= epsilon\n            x1e += epsilon\n            y1e += epsilon\n            for x, y in iter_circle_intersect_on_line(x0, y0, x1, y1):\n                if x >= x0e and x <= x1e and y >= y0e and y <= y1e:\n                    yield x, y"
        }
      ]
    },
    {
      "pr_number": 12461,
      "pr_title": "FIX: make add_lines work with new colorbar",
      "pr_body": "## PR Summary\r\n\r\nCloses #12458\r\n\r\nSee below for a less pathological example...\r\n\r\n`cbar.add_lines` was not operational after new colorbar changes in 3.0.0.  \r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport matplotlib as mpl\r\nimport numpy as np\r\n\r\nfig = plt.figure()\r\nax = fig.add_axes([0.05, 0.8, 0.9, 0.15])\r\ncmap = mpl.cm.cool\r\nnorm = mpl.colors.Normalize(vmin=-4, vmax=4)\r\nlevels = (-1.0, 1.0, 2.0, 3.0)\r\n\r\ncb = mpl.colorbar.ColorbarBase(ax, cmap=cmap, norm=norm)\r\ncolors_bg = np.tile(list((1.0, 1.0, 1.0, 1.0)), (len(levels), 1))\r\ncb.add_lines(levels=levels, colors=colors_bg, linewidths=1)\r\n\r\n```\r\n\r\n## Before\r\n![cbarold](https://user-images.githubusercontent.com/1562854/46681303-ce871d00-cb9f-11e8-8acd-e5defedfe90c.png)\r\n\r\n\r\n## After\r\n\r\n![cbarnew](https://user-images.githubusercontent.com/1562854/46681265-b3b4a880-cb9f-11e8-8efd-87b24d565751.png)\r\n\r\n```python\r\nimport numpy as np\r\nimport matplotlib.pyplot as plt\r\n\r\nfig, ax = plt.subplots()\r\nX = np.random.rand(10, 10)*10000\r\npcm = ax.pcolormesh(X)\r\n# add 1000 to make colors visible...\r\ncont = ax.contour(X+1000)\r\ncb = fig.colorbar(pcm)\r\ncb.add_lines(cont)\r\nplt.show()\r\n```\r\n\r\n## Before\r\n\r\n![before](https://user-images.githubusercontent.com/1562854/46701766-b4683180-cbd5-11e8-8c18-d994ba47e396.png)\r\n\r\n## After\r\n![new](https://user-images.githubusercontent.com/1562854/46701741-9d294400-cbd5-11e8-9006-708b7ef51fdc.png)\r\n\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-->",
      "issue_id": 12458,
      "issue_title": "add_lines misses lines for matplotlib.colorbar.ColorbarBase",
      "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\nFor matplotlib.colorbar.ColorbarBase(...) usage of add_lines(...) may yield missing lines/poorly adjusted lines.\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug, also minimizing the number of dependencies required-->\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nimport matplotlib as mpl\r\nimport numpy as np\r\n\r\nfig = plt.figure()\r\nax = fig.add_axes([0.05, 0.8, 0.9, 0.15])\r\ncmap = mpl.cm.cool\r\nnorm = mpl.colors.Normalize(vmin=-4, vmax=4)\r\nlevels = (-1.0, 1.0, 2.0, 3.0)\r\n\r\ncb = mpl.colorbar.ColorbarBase(ax, cmap=cmap, norm=norm)\r\ncolors_bg = np.tile(list((1.0, 1.0, 1.0, 1.0)), (len(levels), 1))\r\ncb.add_lines(levels=levels, colors=colors_bg, linewidths=7)\r\n\r\nplt.show()\r\n\r\n\r\n```\r\n\r\n**Expected outcome**\r\n\r\n4 white lines, crossing the colorbar.\r\nUsed to work on matplotlib 2.2.3!\r\n\r\n**Matplotlib version**\r\n  * Operating system: Ubuntu 18.04 LTS\r\n  * Matplotlib version: 3.0.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): Qt5Agg\r\n  * Python version: 3.7.0\r\n\r\nMiniconda install, fully updated.",
      "issue_closed_at": "2018-10-14T19:38:43Z",
      "base_commit": "f93222a555160bf967f02dae42cce39a03384774",
      "changes": [
        {
          "file": "lib/matplotlib/colorbar.py",
          "type": "function",
          "name": "add_lines",
          "class_name": "Colorbar",
          "code": "def add_lines(self, CS, erase=True):\n        '''\n        Add the lines from a non-filled\n        :class:`~matplotlib.contour.ContourSet` to the colorbar.\n\n        Set *erase* to False if these lines should be added to\n        any pre-existing lines.\n        '''\n        if not isinstance(CS, contour.ContourSet) or CS.filled:\n            raise ValueError('add_lines is only for a ContourSet of lines')\n        tcolors = [c[0] for c in CS.tcolors]\n        tlinewidths = [t[0] for t in CS.tlinewidths]\n        # The following was an attempt to get the colorbar lines\n        # to follow subsequent changes in the contour lines,\n        # but more work is needed: specifically, a careful\n        # look at event sequences, and at how\n        # to make one object track another automatically.\n        #tcolors = [col.get_colors()[0] for col in CS.collections]\n        #tlinewidths = [col.get_linewidth()[0] for lw in CS.collections]\n        ColorbarBase.add_lines(self, CS.levels, tcolors, tlinewidths,\n                               erase=erase)"
        }
      ]
    },
    {
      "pr_number": 17163,
      "pr_title": "Fix clipping of markers in PDF backend.",
      "pr_body": "The bbox only contains the points of the marker, but the line will extend outside by half the line width. This was handled before, except when the line is at an angle to the edge, as then the line outside is wider than half a line width. The maximum is at 45\u00b0, or \u221a2.\r\n\r\nThis fixes corners on 'v', '^', '<', '>', 'p', 'h', 'H', 'D', 'd', 'X'.\r\n\r\nFixes #9829.\r\n\r\n## PR Summary\r\n\r\n## PR Checklist\r\n\r\n- [x] Has Pytest style unit tests\r\n- [x] 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/api_changes.rst if API changed in a backward-incompatible way",
      "issue_id": 9829,
      "issue_title": "Vertices clipped for certain markers when plotting more than two points and saving as pdf",
      "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\nThe vertices on certain markers ('^', 'D', 'v') are clipped when using `plot()` to plot data with more than two points and saving the plot as a PDF.\r\n\r\n**Code for reproduction**\r\n\r\n<!--A minimum code snippet required to reproduce the bug, also minimizing the number of dependencies required-->\r\n\r\n```python\r\nimport matplotlib.pyplot as plt\r\nsize = 256, 16\r\nfig,ax = plt.subplots()\r\nnum = 3\r\n\r\nfig,ax = plt.subplots()\r\nax.plot([i+1 for i in range(num)],[1 for i in range(num)], '^', markersize=3, markeredgewidth=0.7, color='green', markeredgecolor='black')\r\nax.set_xlim(0, num +1)\r\nax.set_xticks(())\r\nax.set_yticks(())\r\nfig.savefig('test.pdf') # This doesn't work properly.\r\nfig.savefig('test.svg')\r\n```\r\n\r\n**Actual outcome**\r\n\r\n<!--The output produced by the above code, which may be a screenshot, console output, etc.-->\r\n\r\n![pdfmarker](https://user-images.githubusercontent.com/8723338/33104959-e7cacfd6-cef8-11e7-880a-0e8aa8643454.png)\r\n![svgmarker](https://user-images.githubusercontent.com/8723338/33104963-ea6f906e-cef8-11e7-8742-ce5b2421c337.png)\r\n\r\nThe top image is of the marker from the .pdf file. The bottom image is of the marker from the .svg file.\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\nThe marker in the .pdf file should look like the marker in the .svg file.\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: Ubuntu 17.04\r\n  * Matplotlib version: 2.1.0\r\n  * Matplotlib backend (`print(matplotlib.get_backend())`): TkAgg\r\n  * Python version: Python 3.5.3\r\n  * Jupyter version (if applicable):\r\n  * Other libraries: \r\n\r\nI installed matplotlib via pip.\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",
      "issue_closed_at": "2020-06-10T20:38:57Z",
      "base_commit": "f42b24f534ce5d9eb89d95387695bb2cee017829",
      "changes": [
        {
          "file": "lib/matplotlib/backends/backend_pdf.py",
          "type": "function",
          "name": "markerObject",
          "class_name": "PdfFile",
          "code": "def markerObject(self, path, trans, fill, stroke, lw, joinstyle,\n                     capstyle):\n        \"\"\"Return name of a marker XObject representing the given path.\"\"\"\n        # self.markers used by markerObject, writeMarkers, close:\n        # mapping from (path operations, fill?, stroke?) to\n        #   [name, object reference, bounding box, linewidth]\n        # This enables different draw_markers calls to share the XObject\n        # if the gc is sufficiently similar: colors etc can vary, but\n        # the choices of whether to fill and whether to stroke cannot.\n        # We need a bounding box enclosing all of the XObject path,\n        # but since line width may vary, we store the maximum of all\n        # occurring line widths in self.markers.\n        # close() is somewhat tightly coupled in that it expects the\n        # first two components of each value in self.markers to be the\n        # name and object reference.\n        pathops = self.pathOperations(path, trans, simplify=False)\n        key = (tuple(pathops), bool(fill), bool(stroke), joinstyle, capstyle)\n        result = self.markers.get(key)\n        if result is None:\n            name = Name('M%d' % len(self.markers))\n            ob = self.reserveObject('marker %d' % len(self.markers))\n            bbox = path.get_extents(trans)\n            self.markers[key] = [name, ob, bbox, lw]\n        else:\n            if result[-1] < lw:\n                result[-1] = lw\n            name = result[0]\n        return name"
        }
      ]
    },
    {
      "pr_number": 2587,
      "pr_title": "Make backend_pgf more flexible when saving to file-handles or streams (fix #1625).",
      "pr_body": "Since binary data and thus raster images cannot be embedded in pgf code, saving to a stream was prohibited in backend_pgf. This PR allows saving pgf code to streams after deactivating draw_image() and emitting a user warning.\n\nI'll merge this in a few days if there are no objections (fixing issue #1625).\n",
      "issue_id": 1625,
      "issue_title": "saving pgf to a stream is not supported",
      "issue_body": "Hi,\n\nThe pgf output does not support a stream as illustrated by this snippet\n\n``` python\nimport sys\nplt.plot([1,2])\nplt.savefig(sys.stdout, format='pgf')\n```\n\nIt returns:\n\n``` python\nValueError: saving pgf to a stream is not supported, consider using the pdf option of the pgf-backend\n```\n\nOther formats like png, eps, ps, svg support it. I don't see any good reason to do not support streams for pgf and I guess it is a bug :)\n\nThanks.\n",
      "issue_closed_at": "2013-11-12T13:20:52Z",
      "base_commit": "c91589c024aa4c95288173112d3d5c44e1703d27",
      "changes": [
        {
          "file": "lib/matplotlib/backends/backend_pgf.py",
          "type": "line",
          "name": "line 12",
          "code": "import codecs\nimport atexit\nimport weakref\n\nimport matplotlib as mpl\nfrom matplotlib.backend_bases import RendererBase, GraphicsContextBase,\\"
        },
        {
          "file": "lib/matplotlib/backends/backend_pgf.py",
          "type": "function",
          "name": "__init__",
          "class_name": "FigureManagerPgf",
          "code": "def __init__(self, *args):\n        FigureManagerBase.__init__(self, *args)"
        },
        {
          "file": "lib/matplotlib/backends/backend_pgf.py",
          "type": "function",
          "name": "print_pgf",
          "class_name": "FigureCanvasPgf",
          "code": "def print_pgf(self, fname_or_fh, *args, **kwargs):\n        \"\"\"\n        Output pgf commands for drawing the figure so it can be included and\n        rendered in latex documents.\n        \"\"\"\n        if kwargs.get(\"dryrun\", False):\n            self._print_pgf_to_fh(None, *args, **kwargs)\n            return\n\n        # figure out where the pgf is to be written to\n        if is_string_like(fname_or_fh):\n            with codecs.open(fname_or_fh, \"w\", encoding=\"utf-8\") as fh:\n                self._print_pgf_to_fh(fh, *args, **kwargs)\n        elif is_writable_file_like(fname_or_fh):\n            raise ValueError(\"saving pgf to a stream is not supported, \" +\n                             \"consider using the pdf option of the pgf-backend\")\n        else:\n            raise ValueError(\"filename must be a path\")"
        }
      ]
    }
  ]
}