{
  "Selected_candidate": {
    "pr_number": 9999,
    "pr_title": "improve legend docstring",
    "pr_body": "## PR Summary\r\n\r\nThis improves the legend docstrings:\r\n- describe handles and labels\r\n- add call signatures to `Axes.legend()`\r\n- Structure and reorder `Axes.legend()` so that the most common use case is at the top.\r\n\r\nalso fixes #8668",
    "issue_id": 8668,
    "issue_title": "handles keyword argument not documented in the help of legend",
    "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\nThe following on-line documentation has an example where the `handles` keyword is used in a call to `plt.legend`: <http://matplotlib.org/users/legend_guide.html#controlling-the-legend-entries>\r\n\r\nThis keyword argument is not present in the internal function documentation.\r\n\r\n**Matplotlib version**\r\n  * Operating System: Linux (Xubuntu 16.04)\r\n  * Matplotlib Version: 2.0.0\r\n  * Python Version: 3.6\r\n\r\n",
    "issue_closed_at": "2017-12-18T15:29:15Z",
    "base_commit": "7a6bab7ca74308de0afc9656573b9c7de851c236",
    "changes": [
      {
        "file": "lib/matplotlib/axes/_axes.py",
        "type": "function",
        "name": "legend",
        "class_name": "Axes",
        "code": "def legend(self, *args, **kwargs):\n        \"\"\"\n        Places a legend on the axes.\n\n        To make a legend for lines which already exist on the axes\n        (via plot for instance), simply call this function with an iterable\n        of strings, one for each legend item. For example::\n\n            ax.plot([1, 2, 3])\n            ax.legend(['A simple line'])\n\n        However, in order to keep the \"label\" and the legend element\n        instance together, it is preferable to specify the label either at\n        artist creation, or by calling the\n        :meth:`~matplotlib.artist.Artist.set_label` method on the artist::\n\n            line, = ax.plot([1, 2, 3], label='Inline label')\n            # Overwrite the label by calling the method.\n            line.set_label('Label via method')\n            ax.legend()\n\n        Specific lines can be excluded from the automatic legend element\n        selection by defining a label starting with an underscore.\n        This is default for all artists, so calling :meth:`legend` without\n        any arguments and without setting the labels manually will result in\n        no legend being drawn.\n\n        For full control of which artists have a legend entry, it is possible\n        to pass an iterable of legend artists followed by an iterable of\n        legend labels respectively::\n\n           legend((line1, line2, line3), ('label1', 'label2', 'label3'))\n\n        Parameters\n        ----------\n\n        loc : int or string or pair of floats, default: 'upper right'\n            The location of the legend. Possible codes are:\n\n                ===============   =============\n                Location String   Location Code\n                ===============   =============\n                'best'            0\n                'upper right'     1\n                'upper left'      2\n                'lower left'      3\n                'lower right'     4\n                'right'           5\n                'center left'     6\n                'center right'    7\n                'lower center'    8\n                'upper center'    9\n                'center'          10\n                ===============   =============\n\n\n            Alternatively can be a 2-tuple giving ``x, y`` of the lower-left\n            corner of the legend in axes coordinates (in which case\n            ``bbox_to_anchor`` will be ignored).\n\n        bbox_to_anchor : `~.BboxBase` or pair of floats\n            Specify any arbitrary location for the legend in `bbox_transform`\n            coordinates (default Axes coordinates).\n\n            For example, to put the legend's upper right hand corner in the\n            center of the axes the following keywords can be used::\n\n               loc='upper right', bbox_to_anchor=(0.5, 0.5)\n\n        ncol : integer\n            The number of columns that the legend has. Default is 1.\n\n        prop : None or :class:`matplotlib.font_manager.FontProperties` or dict\n            The font properties of the legend. If None (default), the current\n            :data:`matplotlib.rcParams` will be used.\n\n        fontsize : int or float or {'xx-small', 'x-small', 'small', 'medium', \\\n'large', 'x-large', 'xx-large'}\n            Controls the font size of the legend. If the value is numeric the\n            size will be the absolute font size in points. String values are\n            relative to the current default font size. This argument is only\n            used if `prop` is not specified.\n\n        numpoints : None or int\n            The number of marker points in the legend when creating a legend\n            entry for a line/:class:`matplotlib.lines.Line2D`.\n            Default is ``None`` which will take the value from the\n            ``legend.numpoints`` :data:`rcParam<matplotlib.rcParams>`.\n\n        scatterpoints : None or int\n            The number of marker points in the legend when creating a legend\n            entry for a scatter plot/\n            :class:`matplotlib.collections.PathCollection`.\n            Default is ``None`` which will take the value from the\n            ``legend.scatterpoints`` :data:`rcParam<matplotlib.rcParams>`.\n\n        scatteryoffsets : iterable of floats\n            The vertical offset (relative to the font size) for the markers\n            created for a scatter plot legend entry. 0.0 is at the base the\n            legend text, and 1.0 is at the top. To draw all markers at the\n            same height, set to ``[0.5]``. Default ``[0.375, 0.5, 0.3125]``.\n\n        markerscale : None or int or float\n            The relative size of legend markers compared with the originally\n            drawn ones. Default is ``None`` which will take the value from\n            the ``legend.markerscale`` :data:`rcParam <matplotlib.rcParams>`.\n\n        markerfirst : bool\n            If *True*, legend marker is placed to the left of the legend label.\n            If *False*, legend marker is placed to the right of the legend\n            label.\n            Default is *True*.\n\n        frameon : None or bool\n            Control whether the legend should be drawn on a patch (frame).\n            Default is ``None`` which will take the value from the\n            ``legend.frameon`` :data:`rcParam<matplotlib.rcParams>`.\n\n        fancybox : None or bool\n            Control whether round edges should be enabled around\n            the :class:`~matplotlib.patches.FancyBboxPatch` which\n            makes up the legend's background.\n            Default is ``None`` which will take the value from the\n            ``legend.fancybox`` :data:`rcParam<matplotlib.rcParams>`.\n\n        shadow : None or bool\n            Control whether to draw a shadow behind the legend.\n            Default is ``None`` which will take the value from the\n            ``legend.shadow`` :data:`rcParam<matplotlib.rcParams>`.\n\n        framealpha : None or float\n            Control the alpha transparency of the legend's background.\n            Default is ``None`` which will take the value from the\n            ``legend.framealpha`` :data:`rcParam<matplotlib.rcParams>`.\n            If shadow is activated and framealpha is ``None`` the\n            default value is being ignored.\n\n        facecolor : None or \"inherit\" or a color spec\n            Control the legend's background color.\n            Default is ``None`` which will take the value from the\n            ``legend.facecolor`` :data:`rcParam<matplotlib.rcParams>`.\n            If ``\"inherit\"``, it will take the ``axes.facecolor``\n            :data:`rcParam<matplotlib.rcParams>`.\n\n        edgecolor : None or \"inherit\" or a color spec\n            Control the legend's background patch edge color.\n            Default is ``None`` which will take the value from the\n            ``legend.edgecolor`` :data:`rcParam<matplotlib.rcParams>`.\n            If ``\"inherit\"``, it will take the ``axes.edgecolor``\n            :data:`rcParam<matplotlib.rcParams>`.\n\n        mode : {\"expand\", None}\n            If `mode` is set to ``\"expand\"`` the legend will be horizontally\n            expanded to fill the axes area (or `bbox_to_anchor` if defines\n            the legend's size).\n\n        bbox_transform : None or :class:`matplotlib.transforms.Transform`\n            The transform for the bounding box (`bbox_to_anchor`). For a value\n            of ``None`` (default) the Axes'\n            :data:`~matplotlib.axes.Axes.transAxes` transform will be used.\n\n        title : str or None\n            The legend's title. Default is no title (``None``).\n\n        borderpad : float or None\n            The fractional whitespace inside the legend border.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.borderpad`` :data:`rcParam<matplotlib.rcParams>`.\n\n        labelspacing : float or None\n            The vertical space between the legend entries.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.labelspacing`` :data:`rcParam<matplotlib.rcParams>`.\n\n        handlelength : float or None\n            The length of the legend handles.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.handlelength`` :data:`rcParam<matplotlib.rcParams>`.\n\n        handletextpad : float or None\n            The pad between the legend handle and text.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.handletextpad`` :data:`rcParam<matplotlib.rcParams>`.\n\n        borderaxespad : float or None\n            The pad between the axes and legend border.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.borderaxespad`` :data:`rcParam<matplotlib.rcParams>`.\n\n        columnspacing : float or None\n            The spacing between columns.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.columnspacing`` :data:`rcParam<matplotlib.rcParams>`.\n\n        handler_map : dict or None\n            The custom dictionary mapping instances or types to a legend\n            handler. This `handler_map` updates the default handler map\n            found at :func:`matplotlib.legend.Legend.get_legend_handler_map`.\n\n        Returns\n        -------\n\n        :class:`matplotlib.legend.Legend` instance\n\n        Notes\n        -----\n\n        Not all kinds of artist are supported by the legend command. See\n        :ref:`sphx_glr_tutorials_intermediate_legend_guide.py` for details.\n\n        Examples\n        --------\n\n        .. plot:: gallery/api/legend.py\n\n        \"\"\"\n        handles, labels, extra_args, kwargs = mlegend._parse_legend_args(\n                [self],\n                *args,\n                **kwargs)\n        if len(extra_args):\n            raise TypeError('legend only accepts two non-keyword arguments')\n        self.legend_ = mlegend.Legend(self, handles, labels, **kwargs)\n        self.legend_._remove_method = lambda h: setattr(self, 'legend_', None)\n        return self.legend_"
      },
      {
        "file": "lib/matplotlib/figure.py",
        "type": "function",
        "name": "legend",
        "class_name": "Figure",
        "code": "def legend(self, *args, **kwargs):\n        \"\"\"\n        Place a legend on the figure.\n\n        To make a legend from existing artists on every axes::\n\n          legend()\n\n        To make a legend for a list of lines and labels::\n\n          legend( (line1, line2, line3),\n                  ('label1', 'label2', 'label3'),\n                  loc='upper right')\n\n        These can also be specified by keyword::\n\n          legend(handles=(line1, line2, line3),\n                labels=('label1', 'label2', 'label3'),\n                loc='upper right')\n\n        Parameters\n        ----------\n\n        loc : int or string or pair of floats, default: 'upper right'\n            The location of the legend. Possible codes are:\n\n                ===============   =============\n                Location String   Location Code\n                ===============   =============\n                'best'            0\n                'upper right'     1\n                'upper left'      2\n                'lower left'      3\n                'lower right'     4\n                'right'           5\n                'center left'     6\n                'center right'    7\n                'lower center'    8\n                'upper center'    9\n                'center'          10\n                ===============   =============\n\n\n            Alternatively can be a 2-tuple giving ``x, y`` of the lower-left\n            corner of the legend in axes coordinates (in which case\n            ``bbox_to_anchor`` will be ignored).\n\n        bbox_to_anchor : `~.BboxBase` or pair of floats\n            Specify any arbitrary location for the legend in `bbox_transform`\n            coordinates (default Axes coordinates).\n\n            For example, to put the legend's upper right hand corner in the\n            center of the axes the following keywords can be used::\n\n               loc='upper right', bbox_to_anchor=(0.5, 0.5)\n\n        ncol : integer\n            The number of columns that the legend has. Default is 1.\n\n        prop : None or :class:`matplotlib.font_manager.FontProperties` or dict\n            The font properties of the legend. If None (default), the current\n            :data:`matplotlib.rcParams` will be used.\n\n        fontsize : int or float or {'xx-small', 'x-small', 'small', 'medium', \\\n'large', 'x-large', 'xx-large'}\n            Controls the font size of the legend. If the value is numeric the\n            size will be the absolute font size in points. String values are\n            relative to the current default font size. This argument is only\n            used if `prop` is not specified.\n\n        numpoints : None or int\n            The number of marker points in the legend when creating a legend\n            entry for a line/:class:`matplotlib.lines.Line2D`.\n            Default is ``None`` which will take the value from the\n            ``legend.numpoints`` :data:`rcParam<matplotlib.rcParams>`.\n\n        scatterpoints : None or int\n            The number of marker points in the legend when creating a legend\n            entry for a scatter plot/\n            :class:`matplotlib.collections.PathCollection`.\n            Default is ``None`` which will take the value from the\n            ``legend.scatterpoints`` :data:`rcParam<matplotlib.rcParams>`.\n\n        scatteryoffsets : iterable of floats\n            The vertical offset (relative to the font size) for the markers\n            created for a scatter plot legend entry. 0.0 is at the base the\n            legend text, and 1.0 is at the top. To draw all markers at the\n            same height, set to ``[0.5]``. Default ``[0.375, 0.5, 0.3125]``.\n\n        markerscale : None or int or float\n            The relative size of legend markers compared with the originally\n            drawn ones. Default is ``None`` which will take the value from\n            the ``legend.markerscale`` :data:`rcParam <matplotlib.rcParams>`.\n\n        markerfirst : bool\n            If *True*, legend marker is placed to the left of the legend label.\n            If *False*, legend marker is placed to the right of the legend\n            label.\n            Default is *True*.\n\n        frameon : None or bool\n            Control whether the legend should be drawn on a patch (frame).\n            Default is ``None`` which will take the value from the\n            ``legend.frameon`` :data:`rcParam<matplotlib.rcParams>`.\n\n        fancybox : None or bool\n            Control whether round edges should be enabled around\n            the :class:`~matplotlib.patches.FancyBboxPatch` which\n            makes up the legend's background.\n            Default is ``None`` which will take the value from the\n            ``legend.fancybox`` :data:`rcParam<matplotlib.rcParams>`.\n\n        shadow : None or bool\n            Control whether to draw a shadow behind the legend.\n            Default is ``None`` which will take the value from the\n            ``legend.shadow`` :data:`rcParam<matplotlib.rcParams>`.\n\n        framealpha : None or float\n            Control the alpha transparency of the legend's background.\n            Default is ``None`` which will take the value from the\n            ``legend.framealpha`` :data:`rcParam<matplotlib.rcParams>`.\n            If shadow is activated and framealpha is ``None`` the\n            default value is being ignored.\n\n        facecolor : None or \"inherit\" or a color spec\n            Control the legend's background color.\n            Default is ``None`` which will take the value from the\n            ``legend.facecolor`` :data:`rcParam<matplotlib.rcParams>`.\n            If ``\"inherit\"``, it will take the ``axes.facecolor``\n            :data:`rcParam<matplotlib.rcParams>`.\n\n        edgecolor : None or \"inherit\" or a color spec\n            Control the legend's background patch edge color.\n            Default is ``None`` which will take the value from the\n            ``legend.edgecolor`` :data:`rcParam<matplotlib.rcParams>`.\n            If ``\"inherit\"``, it will take the ``axes.edgecolor``\n            :data:`rcParam<matplotlib.rcParams>`.\n\n        mode : {\"expand\", None}\n            If `mode` is set to ``\"expand\"`` the legend will be horizontally\n            expanded to fill the axes area (or `bbox_to_anchor` if defines\n            the legend's size).\n\n        bbox_transform : None or :class:`matplotlib.transforms.Transform`\n            The transform for the bounding box (`bbox_to_anchor`). For a value\n            of ``None`` (default) the Axes'\n            :data:`~matplotlib.axes.Axes.transAxes` transform will be used.\n\n        title : str or None\n            The legend's title. Default is no title (``None``).\n\n        borderpad : float or None\n            The fractional whitespace inside the legend border.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.borderpad`` :data:`rcParam<matplotlib.rcParams>`.\n\n        labelspacing : float or None\n            The vertical space between the legend entries.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.labelspacing`` :data:`rcParam<matplotlib.rcParams>`.\n\n        handlelength : float or None\n            The length of the legend handles.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.handlelength`` :data:`rcParam<matplotlib.rcParams>`.\n\n        handletextpad : float or None\n            The pad between the legend handle and text.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.handletextpad`` :data:`rcParam<matplotlib.rcParams>`.\n\n        borderaxespad : float or None\n            The pad between the axes and legend border.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.borderaxespad`` :data:`rcParam<matplotlib.rcParams>`.\n\n        columnspacing : float or None\n            The spacing between columns.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.columnspacing`` :data:`rcParam<matplotlib.rcParams>`.\n\n        handler_map : dict or None\n            The custom dictionary mapping instances or types to a legend\n            handler. This `handler_map` updates the default handler map\n            found at :func:`matplotlib.legend.Legend.get_legend_handler_map`.\n\n        Returns\n        -------\n        :class:`matplotlib.legend.Legend` instance\n\n        Notes\n        -----\n        Not all kinds of artist are supported by the legend command. See\n        :ref:`sphx_glr_tutorials_intermediate_legend_guide.py` for details.\n        \"\"\"\n\n        handles, labels, extra_args, kwargs = mlegend._parse_legend_args(\n                self.axes,\n                *args,\n                **kwargs)\n        # check for third arg\n        if len(extra_args):\n            # cbook.warn_deprecated(\n            #     \"2.1\",\n            #     \"Figure.legend will accept no more than two \"\n            #     \"positional arguments in the future.  Use \"\n            #     \"'fig.legend(handles, labels, loc=location)' \"\n            #     \"instead.\")\n            # kwargs['loc'] = extra_args[0]\n            # extra_args = extra_args[1:]\n            pass\n        l = mlegend.Legend(self, handles, labels, *extra_args, **kwargs)\n        self.legends.append(l)\n        l._remove_method = lambda h: self.legends.remove(h)\n        self.stale = True\n        return l"
      },
      {
        "file": "lib/matplotlib/legend.py",
        "type": "function",
        "name": "_update_bbox_to_anchor",
        "class_name": "DraggableLegend",
        "code": "def _update_bbox_to_anchor(self, loc_in_canvas):\n\n        tr = self.legend.axes.transAxes\n        loc_in_bbox = tr.transform_point(loc_in_canvas)\n\n        self.legend.set_bbox_to_anchor(loc_in_bbox)"
      },
      {
        "file": "lib/matplotlib/legend.py",
        "type": "function",
        "name": "__init__",
        "class_name": "Legend",
        "code": "def __init__(self, parent, handles, labels,\n                 loc=None,\n                 numpoints=None,    # the number of points in the legend line\n                 markerscale=None,  # the relative size of legend markers\n                                    # vs. original\n                 markerfirst=True,  # controls ordering (left-to-right) of\n                                    # legend marker and label\n                 scatterpoints=None,    # number of scatter points\n                 scatteryoffsets=None,\n                 prop=None,          # properties for the legend texts\n                 fontsize=None,        # keyword to set font size directly\n\n                 # spacing & pad defined as a fraction of the font-size\n                 borderpad=None,      # the whitespace inside the legend border\n                 labelspacing=None,   # the vertical space between the legend\n                                      # entries\n                 handlelength=None,   # the length of the legend handles\n                 handleheight=None,   # the height of the legend handles\n                 handletextpad=None,  # the pad between the legend handle\n                                      # and text\n                 borderaxespad=None,  # the pad between the axes and legend\n                                      # border\n                 columnspacing=None,  # spacing between columns\n\n                 ncol=1,     # number of columns\n                 mode=None,  # mode for horizontal distribution of columns.\n                             # None, \"expand\"\n\n                 fancybox=None,  # True use a fancy box, false use a rounded\n                                 # box, none use rc\n                 shadow=None,\n                 title=None,  # set a title for the legend\n\n                 framealpha=None,  # set frame alpha\n                 edgecolor=None,  # frame patch edgecolor\n                 facecolor=None,  # frame patch facecolor\n\n                 bbox_to_anchor=None,  # bbox that the legend will be anchored.\n                 bbox_transform=None,  # transform for the bbox\n                 frameon=None,  # draw frame\n                 handler_map=None,\n                 ):\n        \"\"\"\n        - *parent*: the artist that contains the legend\n        - *handles*: a list of artists (lines, patches) to be added to the\n                      legend\n        - *labels*: a list of strings to label the legend\n\n        Parameters\n        ----------\n\n        loc : int or string or pair of floats, default: 'upper right'\n            The location of the legend. Possible codes are:\n\n                ===============   =============\n                Location String   Location Code\n                ===============   =============\n                'best'            0\n                'upper right'     1\n                'upper left'      2\n                'lower left'      3\n                'lower right'     4\n                'right'           5\n                'center left'     6\n                'center right'    7\n                'lower center'    8\n                'upper center'    9\n                'center'          10\n                ===============   =============\n\n\n            Alternatively can be a 2-tuple giving ``x, y`` of the lower-left\n            corner of the legend in axes coordinates (in which case\n            ``bbox_to_anchor`` will be ignored).\n\n        bbox_to_anchor : `~.BboxBase` or pair of floats\n            Specify any arbitrary location for the legend in `bbox_transform`\n            coordinates (default Axes coordinates).\n\n            For example, to put the legend's upper right hand corner in the\n            center of the axes the following keywords can be used::\n\n               loc='upper right', bbox_to_anchor=(0.5, 0.5)\n\n        ncol : integer\n            The number of columns that the legend has. Default is 1.\n\n        prop : None or :class:`matplotlib.font_manager.FontProperties` or dict\n            The font properties of the legend. If None (default), the current\n            :data:`matplotlib.rcParams` will be used.\n\n        fontsize : int or float or {'xx-small', 'x-small', 'small', 'medium', \\\n'large', 'x-large', 'xx-large'}\n            Controls the font size of the legend. If the value is numeric the\n            size will be the absolute font size in points. String values are\n            relative to the current default font size. This argument is only\n            used if `prop` is not specified.\n\n        numpoints : None or int\n            The number of marker points in the legend when creating a legend\n            entry for a line/:class:`matplotlib.lines.Line2D`.\n            Default is ``None`` which will take the value from the\n            ``legend.numpoints`` :data:`rcParam<matplotlib.rcParams>`.\n\n        scatterpoints : None or int\n            The number of marker points in the legend when creating a legend\n            entry for a scatter plot/\n            :class:`matplotlib.collections.PathCollection`.\n            Default is ``None`` which will take the value from the\n            ``legend.scatterpoints`` :data:`rcParam<matplotlib.rcParams>`.\n\n        scatteryoffsets : iterable of floats\n            The vertical offset (relative to the font size) for the markers\n            created for a scatter plot legend entry. 0.0 is at the base the\n            legend text, and 1.0 is at the top. To draw all markers at the\n            same height, set to ``[0.5]``. Default ``[0.375, 0.5, 0.3125]``.\n\n        markerscale : None or int or float\n            The relative size of legend markers compared with the originally\n            drawn ones. Default is ``None`` which will take the value from\n            the ``legend.markerscale`` :data:`rcParam <matplotlib.rcParams>`.\n\n        markerfirst : bool\n            If *True*, legend marker is placed to the left of the legend label.\n            If *False*, legend marker is placed to the right of the legend\n            label.\n            Default is *True*.\n\n        frameon : None or bool\n            Control whether the legend should be drawn on a patch (frame).\n            Default is ``None`` which will take the value from the\n            ``legend.frameon`` :data:`rcParam<matplotlib.rcParams>`.\n\n        fancybox : None or bool\n            Control whether round edges should be enabled around\n            the :class:`~matplotlib.patches.FancyBboxPatch` which\n            makes up the legend's background.\n            Default is ``None`` which will take the value from the\n            ``legend.fancybox`` :data:`rcParam<matplotlib.rcParams>`.\n\n        shadow : None or bool\n            Control whether to draw a shadow behind the legend.\n            Default is ``None`` which will take the value from the\n            ``legend.shadow`` :data:`rcParam<matplotlib.rcParams>`.\n\n        framealpha : None or float\n            Control the alpha transparency of the legend's background.\n            Default is ``None`` which will take the value from the\n            ``legend.framealpha`` :data:`rcParam<matplotlib.rcParams>`.\n            If shadow is activated and framealpha is ``None`` the\n            default value is being ignored.\n\n        facecolor : None or \"inherit\" or a color spec\n            Control the legend's background color.\n            Default is ``None`` which will take the value from the\n            ``legend.facecolor`` :data:`rcParam<matplotlib.rcParams>`.\n            If ``\"inherit\"``, it will take the ``axes.facecolor``\n            :data:`rcParam<matplotlib.rcParams>`.\n\n        edgecolor : None or \"inherit\" or a color spec\n            Control the legend's background patch edge color.\n            Default is ``None`` which will take the value from the\n            ``legend.edgecolor`` :data:`rcParam<matplotlib.rcParams>`.\n            If ``\"inherit\"``, it will take the ``axes.edgecolor``\n            :data:`rcParam<matplotlib.rcParams>`.\n\n        mode : {\"expand\", None}\n            If `mode` is set to ``\"expand\"`` the legend will be horizontally\n            expanded to fill the axes area (or `bbox_to_anchor` if defines\n            the legend's size).\n\n        bbox_transform : None or :class:`matplotlib.transforms.Transform`\n            The transform for the bounding box (`bbox_to_anchor`). For a value\n            of ``None`` (default) the Axes'\n            :data:`~matplotlib.axes.Axes.transAxes` transform will be used.\n\n        title : str or None\n            The legend's title. Default is no title (``None``).\n\n        borderpad : float or None\n            The fractional whitespace inside the legend border.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.borderpad`` :data:`rcParam<matplotlib.rcParams>`.\n\n        labelspacing : float or None\n            The vertical space between the legend entries.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.labelspacing`` :data:`rcParam<matplotlib.rcParams>`.\n\n        handlelength : float or None\n            The length of the legend handles.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.handlelength`` :data:`rcParam<matplotlib.rcParams>`.\n\n        handletextpad : float or None\n            The pad between the legend handle and text.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.handletextpad`` :data:`rcParam<matplotlib.rcParams>`.\n\n        borderaxespad : float or None\n            The pad between the axes and legend border.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.borderaxespad`` :data:`rcParam<matplotlib.rcParams>`.\n\n        columnspacing : float or None\n            The spacing between columns.\n            Measured in font-size units.\n            Default is ``None`` which will take the value from the\n            ``legend.columnspacing`` :data:`rcParam<matplotlib.rcParams>`.\n\n        handler_map : dict or None\n            The custom dictionary mapping instances or types to a legend\n            handler. This `handler_map` updates the default handler map\n            found at :func:`matplotlib.legend.Legend.get_legend_handler_map`.\n\n        Notes\n        -----\n\n        Users can specify any arbitrary location for the legend using the\n        *bbox_to_anchor* keyword argument. bbox_to_anchor can be an instance\n        of BboxBase(or its derivatives) or a tuple of 2 or 4 floats.\n        See :meth:`set_bbox_to_anchor` for more detail.\n\n        The legend location can be specified by setting *loc* with a tuple of\n        2 floats, which is interpreted as the lower-left corner of the legend\n        in the normalized axes coordinate.\n        \"\"\"\n        # local import only to avoid circularity\n        from matplotlib.axes import Axes\n        from matplotlib.figure import Figure\n\n        Artist.__init__(self)\n\n        if prop is None:\n            if fontsize is not None:\n                self.prop = FontProperties(size=fontsize)\n            else:\n                self.prop = FontProperties(size=rcParams[\"legend.fontsize\"])\n        elif isinstance(prop, dict):\n            self.prop = FontProperties(**prop)\n            if \"size\" not in prop:\n                self.prop.set_size(rcParams[\"legend.fontsize\"])\n        else:\n            self.prop = prop\n\n        self._fontsize = self.prop.get_size_in_points()\n\n        self.texts = []\n        self.legendHandles = []\n        self._legend_title_box = None\n\n        #: A dictionary with the extra handler mappings for this Legend\n        #: instance.\n        self._custom_handler_map = handler_map\n\n        locals_view = locals()\n        for name in [\"numpoints\", \"markerscale\", \"shadow\", \"columnspacing\",\n                     \"scatterpoints\", \"handleheight\", 'borderpad',\n                     'labelspacing', 'handlelength', 'handletextpad',\n                     'borderaxespad']:\n            if locals_view[name] is None:\n                value = rcParams[\"legend.\" + name]\n            else:\n                value = locals_view[name]\n            setattr(self, name, value)\n        del locals_view\n        # trim handles and labels if illegal label...\n        for label, handle in zip(labels[:], handles[:]):\n                if (isinstance(label, six.string_types) and\n                        label.startswith('_')):\n                    warnings.warn('The handle {!r} has a label of {!r} which '\n                                  'cannot be automatically added to the '\n                                  'legend.'.format(handle, label))\n                    labels.remove(label)\n                    handles.remove(handle)\n\n        handles = list(handles)\n        if len(handles) < 2:\n            ncol = 1\n        self._ncol = ncol\n\n        if self.numpoints <= 0:\n            raise ValueError(\"numpoints must be > 0; it was %d\" % numpoints)\n\n        # introduce y-offset for handles of the scatter plot\n        if scatteryoffsets is None:\n            self._scatteryoffsets = np.array([3. / 8., 4. / 8., 2.5 / 8.])\n        else:\n            self._scatteryoffsets = np.asarray(scatteryoffsets)\n        reps = self.scatterpoints // len(self._scatteryoffsets) + 1\n        self._scatteryoffsets = np.tile(self._scatteryoffsets,\n                                        reps)[:self.scatterpoints]\n\n        # _legend_box is an OffsetBox instance that contains all\n        # legend items and will be initialized from _init_legend_box()\n        # method.\n        self._legend_box = None\n\n        if isinstance(parent, Axes):\n            self.isaxes = True\n            self.axes = parent\n            self.set_figure(parent.figure)\n        elif isinstance(parent, Figure):\n            self.isaxes = False\n            self.set_figure(parent)\n        else:\n            raise TypeError(\"Legend needs either Axes or Figure as parent\")\n        self.parent = parent\n\n        if loc is None:\n            loc = rcParams[\"legend.loc\"]\n            if not self.isaxes and loc in [0, 'best']:\n                loc = 'upper right'\n        if isinstance(loc, six.string_types):\n            if loc not in self.codes:\n                if self.isaxes:\n                    warnings.warn('Unrecognized location \"%s\". Falling back '\n                                  'on \"best\"; valid locations are\\n\\t%s\\n'\n                                  % (loc, '\\n\\t'.join(self.codes)))\n                    loc = 0\n                else:\n                    warnings.warn('Unrecognized location \"%s\". Falling back '\n                                  'on \"upper right\"; '\n                                  'valid locations are\\n\\t%s\\n'\n                                  % (loc, '\\n\\t'.join(self.codes)))\n                    loc = 1\n            else:\n                loc = self.codes[loc]\n        if not self.isaxes and loc == 0:\n            warnings.warn('Automatic legend placement (loc=\"best\") not '\n                          'implemented for figure legend. '\n                          'Falling back on \"upper right\".')\n            loc = 1\n\n        self._mode = mode\n        self.set_bbox_to_anchor(bbox_to_anchor, bbox_transform)\n\n        # We use FancyBboxPatch to draw a legend frame. The location\n        # and size of the box will be updated during the drawing time.\n\n        if facecolor is None:\n            facecolor = rcParams[\"legend.facecolor\"]\n        if facecolor == 'inherit':\n            facecolor = rcParams[\"axes.facecolor\"]\n\n        if edgecolor is None:\n            edgecolor = rcParams[\"legend.edgecolor\"]\n        if edgecolor == 'inherit':\n            edgecolor = rcParams[\"axes.edgecolor\"]\n\n        self.legendPatch = FancyBboxPatch(\n            xy=(0.0, 0.0), width=1., height=1.,\n            facecolor=facecolor,\n            edgecolor=edgecolor,\n            mutation_scale=self._fontsize,\n            snap=True\n            )\n\n        # The width and height of the legendPatch will be set (in the\n        # draw()) to the length that includes the padding. Thus we set\n        # pad=0 here.\n        if fancybox is None:\n            fancybox = rcParams[\"legend.fancybox\"]\n\n        if fancybox:\n            self.legendPatch.set_boxstyle(\"round\", pad=0,\n                                          rounding_size=0.2)\n        else:\n            self.legendPatch.set_boxstyle(\"square\", pad=0)\n\n        self._set_artist_props(self.legendPatch)\n\n        self._drawFrame = frameon\n        if frameon is None:\n            self._drawFrame = rcParams[\"legend.frameon\"]\n\n        # init with null renderer\n        self._init_legend_box(handles, labels, markerfirst)\n\n        # If shadow is activated use framealpha if not\n        # explicitly passed. See Issue 8943\n        if framealpha is None:\n            if shadow:\n                self.get_frame().set_alpha(1)\n            else:\n                self.get_frame().set_alpha(rcParams[\"legend.framealpha\"])\n        else:\n            self.get_frame().set_alpha(framealpha)\n\n        self._loc = loc\n        self.set_title(title)\n        self._last_fontsize_points = self._fontsize\n        self._draggable = None"
      },
      {
        "file": "lib/matplotlib/pyplot.py",
        "type": "function",
        "name": "pause",
        "class_name": null,
        "code": "def pause(interval):\n    \"\"\"\n    Pause for *interval* seconds.\n\n    If there is an active figure, it will be updated and displayed before the\n    pause, and the GUI event loop (if any) will run during the pause.\n\n    This can be used for crude animation.  For more complex animation, see\n    :mod:`matplotlib.animation`.\n\n    Note\n    ----\n    This function is experimental; its behavior may be changed or extended in a\n    future release.\n    \"\"\"\n    manager = _pylab_helpers.Gcf.get_active()\n    if manager is not None:\n        canvas = manager.canvas\n        if canvas.figure.stale:\n            canvas.draw_idle()\n        show(block=False)\n        canvas.start_event_loop(interval)\n    else:\n        time.sleep(interval)"
      }
    ]
  },
  "Justification": "Candidate B is the most helpful because it addresses the legend feature's documentation, closely related to the CURRENT bug's request for adding a \"draggable=True\" keyword to the Legend's initialization. The reported bug directly relates to keyword handling in the legend, which shares a conceptual framework with the CURRENT bug, making it highly relevant for informing the implementation of such a feature. Additionally, both bugs involve altering the functionality of the legend, enhancing the chance that insights from Candidate B could streamline the development process for the CURRENT bug.",
  "instance_id": "matplotlib__matplotlib-23913",
  "repo": "matplotlib/matplotlib",
  "created_at": "2022-09-16T21:51:24Z",
  "problem_statement": "legend draggable as keyword\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### Feature request\r\n\r\n**There is not keyword to make legend draggable at creation**\r\n\r\n<!--A short 1-2 sentences that succinctly describes the bug-->\r\n\r\nIs there a code reason why one can not add a \"draggable=True\" keyword to the __init__ function for Legend?  This would be more handy than having to call it after legend creation.  And, naively, it would seem simple to do.  But maybe there is a reason why it would not work?\n",
  "patch": "diff --git a/lib/matplotlib/legend.py b/lib/matplotlib/legend.py\n--- a/lib/matplotlib/legend.py\n+++ b/lib/matplotlib/legend.py\n@@ -286,6 +286,9 @@ def _update_bbox_to_anchor(self, loc_in_canvas):\n     The custom dictionary mapping instances or types to a legend\n     handler. This *handler_map* updates the default handler map\n     found at `matplotlib.legend.Legend.get_legend_handler_map`.\n+\n+draggable : bool, default: False\n+    Whether the legend can be dragged with the mouse.\n \"\"\")\n \n \n@@ -342,7 +345,8 @@ def __init__(\n         title_fontproperties=None,  # properties for the legend title\n         alignment=\"center\",       # control the alignment within the legend box\n         *,\n-        ncol=1  # synonym for ncols (backward compatibility)\n+        ncol=1,  # synonym for ncols (backward compatibility)\n+        draggable=False  # whether the legend can be dragged with the mouse\n     ):\n         \"\"\"\n         Parameters\n@@ -537,7 +541,9 @@ def val_or_rc(val, rc_name):\n             title_prop_fp.set_size(title_fontsize)\n \n         self.set_title(title, prop=title_prop_fp)\n+\n         self._draggable = None\n+        self.set_draggable(state=draggable)\n \n         # set the text color\n \n"
}