{
  "Selected_candidate": {
    "pr_number": 10985,
    "pr_title": "Fixed #30181 -- Made cache.get() with default work correctly on PyLibMCCache if None is cached.",
    "pr_body": "This PR fixes https://code.djangoproject.com/ticket/30181",
    "issue_id": 30181,
    "issue_title": "Fix cache.get() with default on PyLibMCCache if None is cached",
    "issue_body": "If\nNone\nis saved to the cache, the\ndefault\nkeyword argument in\ncache.get()\nshadows it if using any Memcached backend. This is not consistent with LocMemCache.\nThe issue can be very easily fixed within\nPyLibMCCache\n, as it supports retrieving a default value if key is not present.\nFor\nMemcachedCache\n, unfortunatelly, this is not possible because of\npython-memcached\nlimitations, although I've opened up an issue and PR to the upstream package maintainer that would add functionality that would allow this in\nMemcachedCache\nas well:\n​\nhttps://github.com/linsomniac/python-memcached/issues/159\nI will fix this issue for\nPyLibMCCache\nfor now, and once (if) the upstream PR for\npython-memcached\ngets approved, merged and released, I'll also submit a PR that would fix this issue for\nMemcachedCache\n(although that would require a minimum version of\npython-memcached\n, so that one would probably be a little more complex).",
    "issue_closed_at": "2019-02-14T18:58:15",
    "base_commit": "741ce81a426e4d0cd7581d98d3b8e3290f513f09",
    "changes": [
      {
        "file": "django/core/cache/backends/memcached.py",
        "type": "function",
        "name": "add",
        "class_name": "BaseMemcachedCache",
        "code": "def add(self, key, value, timeout=DEFAULT_TIMEOUT, version=None):\n        key = self.make_key(key, version=version)\n        return self._cache.add(key, value, self.get_backend_timeout(timeout))"
      },
      {
        "file": "django/core/cache/backends/memcached.py",
        "type": "function",
        "name": "touch",
        "class_name": "PyLibMCCache",
        "code": "def touch(self, key, timeout=DEFAULT_TIMEOUT, version=None):\n        key = self.make_key(key, version=version)\n        if timeout == 0:\n            return self._cache.delete(key)\n        return self._cache.touch(key, self.get_backend_timeout(timeout))"
      }
    ]
  },
  "Justification": "Candidate E is the most useful because it addresses similar functionality within the Django framework concerning caching behavior, which could relate to how item_comments are processed in the syndication framework. Both the CURRENT bug and Candidate E deal with the handling of arguments and ensure they behave correctly in their respective operations. The approach of modifying how defaults are handled can provide insights into handling the new comments argument in `feed.add_item()`, especially in cases with optional or default parameters. The candidate's patch addresses a specific functionality improvement that can inspire solutions for the CURRENT bug.",
  "instance_id": "django__django-13230",
  "repo": "django/django",
  "created_at": "2020-07-23T14:59:50Z",
  "problem_statement": "Add support for item_comments to syndication framework\nDescription\n\t\nAdd comments argument to feed.add_item() in syndication.views so that item_comments can be defined directly without having to take the detour via item_extra_kwargs .\nAdditionally, comments is already explicitly mentioned in the feedparser, but not implemented in the view.\n",
  "patch": "diff --git a/django/contrib/syndication/views.py b/django/contrib/syndication/views.py\n--- a/django/contrib/syndication/views.py\n+++ b/django/contrib/syndication/views.py\n@@ -212,6 +212,7 @@ def get_feed(self, obj, request):\n                 author_name=author_name,\n                 author_email=author_email,\n                 author_link=author_link,\n+                comments=self._get_dynamic_attr('item_comments', item),\n                 categories=self._get_dynamic_attr('item_categories', item),\n                 item_copyright=self._get_dynamic_attr('item_copyright', item),\n                 **self.item_extra_kwargs(item)\n"
}