[
  {
    "instance_id": "astropy__astropy-7746",
    "model_patch": "diff --git a/astropy/wcs/wcs.py b/astropy/wcs/wcs.py\nindex 1234567..89abcde 100644\n--- a/astropy/wcs/wcs.py\n+++ b/astropy/wcs/wcs.py\n@@ -1262,6 +1262,9 @@ class WCS(BaseLowLevelWCS):\n                 \"a 1-D array for each axis, followed by an origin.\")\n \n         if len(args) == self.naxis:\n+            if any(len(np.asarray(a)) == 0 for a in args):\n+                return [np.array([]) for _ in range(self.naxis)]\n+\n             axes = [np.asarray(a, dtype=float) for a in args]\n             origin = kwargs['origin']",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11283",
    "model_patch": "diff --git a/django/contrib/auth/migrations/0011_update_proxy_permissions.py b/django/contrib/auth/migrations/0011_update_proxy_permissions.py\nindex e69de29bb2..3a5f0a8a8e 100644\n--- a/django/contrib/auth/migrations/0011_update_proxy_permissions.py\n+++ b/django/contrib/auth/migrations/0011_update_proxy_permissions.py\n@@ -28,6 +28,10 @@ def update_proxy_model_permissions(apps, schema_editor):\n             name=name,\n             content_type=content_type,\n         )\n+        Permission.objects.get_or_create(\n+            codename=permission,\n+            content_type=content_type,\n+            defaults={'name': name},\n+        )\n \n \n def revert_proxy_model_permissions(apps, schema_editor):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12856",
    "model_patch": "diff --git a/django/db/models/options.py b/django/db/models/options.py\nindex 1d2f3a4..5b6c7d8 100644\n--- a/django/db/models/options.py\n+++ b/django/db/models/options.py\n@@ -632,6 +632,17 @@ class Options(BaseOptions):\n         return errors\n \n     def _check_constraints(self):\n+        errors = []\n+        for constraint in self.constraints:\n+            if hasattr(constraint, 'fields'):\n+                for field_name in constraint.fields:\n+                    try:\n+                        self.get_field(field_name)\n+                    except FieldDoesNotExist:\n+                        errors.append(\n+                            checks.Error(\n+                                \"'constraints' refers to the non-existent field '%s'.\" % field_name,\n+                                obj=self.model,\n+                                id='models.E012',\n+                            )\n+                        )\n         return errors",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13401",
    "model_patch": "diff --git a/django/db/models/fields/__init__.py b/django/db/models/fields/__init__.py\nindex 4e5f6c7..a5d3c8e 100644\n--- a/django/db/models/fields/__init__.py\n+++ b/django/db/models/fields/__init__.py\n@@ -2189,6 +2189,20 @@ class Field(RegisterLookupMixin):\n         # of the instances are equal.\n         return self is other\n \n+    def __eq__(self, other):\n+        if not isinstance(other, Field):\n+            return False\n+        if self.model != other.model:\n+            return False\n+        return self.creation_counter == other.creation_counter\n+\n+    def __hash__(self):\n+        return hash((self.creation_counter, self.model))\n+\n+    def __lt__(self, other):\n+        if not isinstance(other, Field):\n+            return NotImplemented\n+        return (self.creation_counter, self.model) < (other.creation_counter, other.model)\n \n class BooleanField(Field):\n     description = _(\"Boolean (Either True or False)\")",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15789",
    "model_patch": "diff --git a/django/utils/html.py b/django/utils/html.py\nindex 8a6e5f3..b1c2d4e 100644\n--- a/django/utils/html.py\n+++ b/django/utils/html.py\n@@ -18,7 +18,7 @@ _json_script_escapes = {\n \n \n def json_script(value, element_id=None, encoder=None):\n-    from django.core.serializers.json import DjangoJSONEncoder\n+    from django.core.serializers.json import DjangoJSONEncoder \n     json_str = json.dumps(\n         value,\n         cls=encoder or DjangoJSONEncoder,\ndiff --git a/tests/utils_tests/test_html.py b/tests/utils_tests/test_html.py\nindex 1a2b3c4..5d6e7f8 100644\n--- a/tests/utils_tests/test_html.py\n+++ b/tests/utils_tests/test_html.py\n@@ -9,6 +9,7 @@ import json\n from datetime import datetime\n \n from django.test import SimpleTestCase\n+from unittest.mock import Mock\n from django.utils.html import (\n     avoid_wrapping, conditional_escape, escape, escapejs, format_html,\n     format_html_join, html_safe, html_script, json_script,\n@@ -234,6 +235,17 @@ class TestUtilsHtml(SimpleTestCase):\n             '<script id=\"test-data\" type=\"application/json\">{\"key\": \"value\"}</script>',\n             json_script({'key': 'value'}, element_id='test-data')\n         )\n+\n+    def test_json_script_with_custom_encoder(self):\n+        class CustomEncoder(json.JSONEncoder):\n+            def encode(self, o):\n+                return '{\"custom\": true}'\n+\n+        self.assertEqual(\n+            json_script({'key': 'value'}, encoder=CustomEncoder),\n+            '<script type=\"application/json\">{\"custom\": true}</script>'\n+        )\n+\n \n class TestEscapeJS(SimpleTestCase):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14730",
    "model_patch": "diff --git a/django/db/models/fields/related.py b/django/db/models/fields/related.py\nindex 5b9d8f5..e1c3b4a 100644\n--- a/django/db/models/fields/related.py\n+++ b/django/db/models/fields/related.py\n@@ -1477,6 +1477,12 @@ class ManyToManyField(RelatedField):\n             self.remote_field.through_fields = through_fields\n \n         if self.remote_field.symmetrical and self.remote_field.model == RECURSIVE_RELATIONSHIP_CONSTANT:\n+            if related_name is not None:\n+                raise ValueError(\n+                    \"Cannot specify a related_name on a symmetrical ManyToManyField.\"\n+                )\n+\n+        if symmetrical is True or (symmetrical is None and to == RECURSIVE_RELATIONSHIP_CONSTANT):\n             # If this is a symmetrical m2m relation on self, ensure the related_name\n             # and related_query_name are absent.\n             if related_name or related_query_name:",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12700",
    "model_patch": "diff --git a/django/views/debug.py b/django/views/debug.py\nindex 2c0e6f3..8b7d1a5 100644\n--- a/django/views/debug.py\n+++ b/django/views/debug.py\n@@ -363,6 +363,12 @@ def cleanse_setting(self, key, value):\n             return self.cleansed_substitute\n         if isinstance(value, dict):\n             return {k: self.cleanse_setting(k, v) for k, v in value.items()}\n+        if isinstance(value, (list, tuple)):\n+            cleansed = []\n+            for v in value:\n+                v = self.cleanse_setting(key, v)\n+                cleansed.append(v)\n+            return type(value)(cleansed)\n         if isinstance(value, str):\n             return value\n         return value",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14855",
    "model_patch": "diff --git a/django/contrib/admin/helpers.py b/django/contrib/admin/helpers.py\nindex 6d5f0e2..c3f1e9b 100644\n--- a/django/contrib/admin/helpers.py\n+++ b/django/contrib/admin/helpers.py\n@@ -100,7 +100,11 @@ class AdminReadonlyField:\n             remote_obj._meta.app_label,\n             remote_obj._meta.model_name,\n         )\n-        url = reverse(url_name, args=[quote(remote_obj.pk)])\n+        url = reverse(\n+            url_name,\n+            args=[quote(remote_obj.pk)],\n+            current_app=self.model_admin.admin_site.name\n+        )\n         return mark_safe(format_html('<a href=\"{}\">{}</a>', url, remote_obj))\n \n     def get_remote_obj(self):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11620",
    "model_patch": "diff --git a/django/core/handlers/exception.py b/django/core/handlers/exception.py\nindex 4c5f1e3..b7c8f9d 100644\n--- a/django/core/handlers/exception.py\n+++ b/django/core/handlers/exception.py\n@@ -34,6 +34,11 @@ def convert_exception_to_response(get_response):\n         if response is None:\n             response = handle_uncaught_exception(request, resolver, sys.exc_info())\n \n+        # If the exception is Http404 and DEBUG is True, return technical 404 response.\n+        if isinstance(response, Http404) and settings.DEBUG:\n+            from django.views import debug\n+            return debug.technical_404_response(request, response)\n+\n         return response\n \n     return inner",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11019",
    "model_patch": "diff --git a/django/forms/widgets.py b/django/forms/widgets.py\nindex 5f2b6d2..e3c4f1a 100644\n--- a/django/forms/widgets.py\n+++ b/django/forms/widgets.py\n@@ -142,7 +142,7 @@ class Media:\n         combined = Media()\n         combined._css_lists = self._css_lists + other._css_lists\n         combined._js_lists = self._js_lists + other._js_lists\n-        combined._ordering = self._ordering | other._ordering\n+        combined._ordering = self._ordering.copy()\n         return combined\n \n     def __str__(self):\n@@ -180,6 +180,11 @@ class Media:\n                 if dependency in js:\n                     before = js.index(dependency)\n                     after = js.index(path)\n+                    # Only add ordering if it doesn't reverse an existing one\n+                    if (path, dependency) not in self._ordering:\n+                        self._ordering.add((dependency, path))\n+                    if before > after:\n+                        js[before], js[after] = js[after], js[before]\n                     if before > after:\n                         warnings.warn(\n                             \"Detected duplicate Media files in an opposite order:\\n\"\n@@ -187,8 +192,6 @@ class Media:\n                             \"%s\" % (dependency, path),\n                             MediaOrderConflictWarning,\n                         )\n-                        js[before], js[after] = js[after], js[before]\n-                    self._ordering.add((dependency, path))\n         return js\n \n     def _get_js(self):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13590",
    "model_patch": "diff --git a/django/db/models/sql/query.py b/django/db/models/sql/query.py\nindex 1234567..89abcde 100644\n--- a/django/db/models/sql/query.py\n+++ b/django/db/models/sql/query.py\n@@ -1117,7 +1117,7 @@ class Query:\n             for sub_value in value\n         )\n         if hasattr(value, '_asdict'):\n             # Preserve named tuple type\n-            value = type(value)(*value)\n+            value = type(value)._make(value)\n \n     elif isinstance(value, list):\n         value = [",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14580",
    "model_patch": "diff --git a/django/db/migrations/writer.py b/django/db/migrations/writer.py\nindex abc1234..def5678 100644\n--- a/django/db/migrations/writer.py\n+++ b/django/db/migrations/writer.py\n@@ -200,6 +200,8 @@ class MigrationWriter:\n             if isinstance(item, str):\n                 if item.startswith(('django.db.models.', 'django.contrib.auth.models.')):\n                     self.add_import(item)\n+            elif isinstance(item, type) and issubclass(item, models.Model):\n+                self.add_import('django.db.models')\n\n     def _sort_imports(self):\n         # Sort imports by the original / from... import / import ... order.",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11815",
    "model_patch": "diff --git a/django/db/migrations/serializer.py b/django/db/migrations/serializer.py\nindex e5d6f7a..b3c4a9e 100644\n--- a/django/db/migrations/serializer.py\n+++ b/django/db/migrations/serializer.py\n@@ -228,7 +228,8 @@ class EnumSerializer(BaseSerializer):\n     def serialize(self):\n         enum_class = self.value.__class__\n         module = enum_class.__module__\n-        return \"%s.%s(%r)\" % (module, enum_class.__qualname__, self.value.value), {}\n+        return \"%s.%s['%s']\" % (\n+            module, enum_class.__qualname__, self.value.name\n+        ), {}\n \n \n class FloatSerializer(BaseSimpleSerializer):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12453",
    "model_patch": "diff --git a/django/db/backends/base/creation.py b/django/db/backends/base/creation.py\nindex bca8376..7bed2be 100644\n--- a/django/db/backends/base/creation.py\n+++ b/django/db/backends/base/creation.py\n@@ -4,7 +4,7 @@ import time\n from django.apps import apps\n from django.conf import settings\n from django.core import serializers\n-from django.db import router\n+from django.db import router, transaction\n from django.utils.six import StringIO\n from django.utils.six.moves import input\n \n@@ -128,8 +128,9 @@ class BaseDatabaseCreation(object):\n         the serialize_db_to_string method.\n         \"\"\"\n         data = StringIO(data)\n-        for obj in serializers.deserialize(\"json\", data, using=self.connection.alias):\n-            obj.save()\n+        with transaction.atomic(using=self.connection.alias):\n+            for obj in serializers.deserialize(\"json\", data, using=self.connection.alias):\n+                obj.save()\n \n     def _get_database_display_str(self, verbosity, database_name):\n         \"\"\"",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13757",
    "model_patch": "diff --git a/django/db/models/fields/json.py b/django/db/models/fields/json.py\nindex abc1234..def5678 100644\n--- a/django/db/models/fields/json.py\n+++ b/django/db/models/fields/json.py\n@@ -XXX,XX +XXX,XX @@ class KeyTransformIsNull(KeyTransform):\n         if not self.rhs:\n             return super().as_sql(compiler, connection)\n         # SQLite and Oracle __isnull=True should only match objects without key\n-        if connection.vendor in ('sqlite', 'oracle'):\n-            return HasKey(self.lhs.lhs, self.lhs.key_name).as_sql(compiler, connection)\n+        if connection.vendor in ('sqlite', 'oracle') and self.rhs:\n+            return HasKey(self.lhs.lhs, self.lhs.key_name).as_sql(compiler, connection)\n         return super().as_sql(compiler, connection)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13768",
    "model_patch": "diff --git a/django/dispatch/dispatcher.py b/django/dispatch/dispatcher.py\n--- a/django/dispatch/dispatcher.py\n+++ b/django/dispatch/dispatcher.py\n@@ -1,4 +1,7 @@\n+import logging\n from weakref import WeakSet\n \n+logger = logging.getLogger('django.dispatch')\n+\n \n class Signal:\n     \"\"\"\n@@ -174,6 +177,7 @@\n                 response = receiver(signal=self, sender=sender, **named)\n                 responses.append((receiver, response))\n             except Exception as err:\n+                logger.exception(\"Error calling %s in Signal.send_robust() (%s)\", receiver.__qualname__, err)\n                 responses.append((receiver, err))\n         return responses",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12308",
    "model_patch": "diff --git a/django/contrib/admin/utils.py b/django/contrib/admin/utils.py\nindex 6f9d8b1..3c7e8f2 100644\n--- a/django/contrib/admin/utils.py\n+++ b/django/contrib/admin/utils.py\n@@ -1,5 +1,6 @@\n from django.db import models\n from django.utils.html import format_html\n+from django.db.models import JSONField\n from django.utils.text import capfirst\n from django.utils.translation import gettext_lazy as _\n \n@@ -137,6 +138,8 @@ def display_for_field(value, field, empty_value_display):\n     if getattr(field, 'flatchoices', None):\n         return dict(field.flatchoices).get(value, empty_value_display)\n     # Boolean fields need special-case null-handling\n+    elif isinstance(field, JSONField):\n+        return field.prepare_value(value)\n     elif isinstance(field, models.BooleanField):\n         return _boolean_icon(value)\n     elif isinstance(field, models.DateTimeField):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11797",
    "model_patch": "diff --git a/django/db/models/sql/subqueries.py b/django/db/models/sql/subqueries.py\nindex abc1234..def5678 100644\n--- a/django/db/models/sql/subqueries.py\n+++ b/django/db/models/sql/subqueries.py\n@@ -100,6 +100,7 @@ class Query:\n         clone = self.clone()\n         clone._for_write = False\n         clone.select = [self.model._meta.pk.name]\n+        clone.group_by = self.group_by[:] if hasattr(self, 'group_by') else None\n         return clone\n \n     def get_compiler(self, *args, **kwargs):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14608",
    "model_patch": "diff --git a/django/forms/formsets.py b/django/forms/formsets.py\nindex 8f8b7e6..d4c3d12 100644\n--- a/django/forms/formsets.py\n+++ b/django/forms/formsets.py\n@@ -66,7 +66,7 @@ class BaseFormSet:\n     def non_form_errors(self):\n         \"\"\"Return an ErrorList of errors that aren't associated with a particular form.\"\"\"\n         if self._non_form_errors is None:\n-            self._non_form_errors = self.error_class(self.errors)\n+            self._non_form_errors = self.error_class(self.errors, error_class='nonform')\n         return self._non_form_errors\n \n     def total_error_count(self):\ndiff --git a/django/forms/utils.py b/django/forms/utils.py\nindex 5b2c3d1..e4f5a67 100644\n--- a/django/forms/utils.py\n+++ b/django/forms/utils.py\n@@ -72,6 +72,9 @@ class ErrorList(UserList, list):\n             if not isinstance(item, str):\n                 item = str(item)\n             if self.error_class == 'nonfield':\n+                self.error_class = 'nonfield'\n+            elif self.error_class == 'nonform':\n+                self.error_class = 'nonform'\n             return format_html(\n                 '<li class=\"{}\">{}</li>',\n                 self.error_class, item",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13658",
    "model_patch": "diff --git a/django/core/management/__init__.py b/django/core/management/__init__.py\nindex abcdef1..1234567 100644\n--- a/django/core/management/__init__.py\n+++ b/django/core/management/__init__.py\n@@ -265,7 +265,12 @@ class ManagementUtility:\n         self.prog_name = os.path.basename(self.argv[0])\n         if self.prog_name == '__main__.py':\n             self.prog_name = 'python -m django'\n-        parser = CommandParser(usage='%(prog)s subcommand [options] [args]', add_help=False, allow_abbrev=False)\n+        parser = CommandParser(\n+            prog=self.prog_name,\n+            usage='%(prog)s subcommand [options] [args]',\n+            add_help=False,\n+            allow_abbrev=False\n+        )\n         parser.add_argument('--settings')\n         parser.add_argument('--pythonpath')",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11583",
    "model_patch": "diff --git a/django/utils/autoreload.py b/django/utils/autoreload.py\nindex 6c9e7b6..f3b5d3a 100644\n--- a/django/utils/autoreload.py\n+++ b/django/utils/autoreload.py\n@@ -129,7 +129,11 @@ def iter_modules_and_files(modules, extra_files):\n             if not path.exists():\n                 continue\n             try:\n-                results.add(path.resolve().absolute())\n+                resolved_path = path.resolve().absolute()\n+                # Skip paths containing null bytes\n+                if '\\x00' in str(resolved_path):\n+                    continue\n+                results.add(resolved_path)\n             except (OSError, RuntimeError, ValueError):\n                 # ValueError could happen when path contains null bytes on Python < 3.8\n                 continue",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11001",
    "model_patch": "diff --git a/django/db/models/sql/compiler.py b/django/db/models/sql/compiler.py\nindex 1234567..89abcde 100644\n--- a/django/db/models/sql/compiler.py\n+++ b/django/db/models/sql/compiler.py\n@@ -234,7 +234,8 @@ class SQLCompiler:\n         # Trim unnecessary ordering from the end of the query\n         if self.query.subquery:\n             return result, []\n-        without_ordering = self.ordering_parts.search(sql).group(1)\n+        sql_oneline = ' '.join(sql.splitlines())\n+        without_ordering = self.ordering_parts.search(sql_oneline).group(1)\n         result = [r for r in result if r[0] not in self.query.annotation_select]\n         ordering_aliases = []\n         for expr in self.query.order_by:",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14787",
    "model_patch": "diff --git a/django/utils/decorators.py b/django/utils/decorators.py\nindex 9b1f9d1..4a6b8c3 100644\n--- a/django/utils/decorators.py\n+++ b/django/utils/decorators.py\n@@ -12,6 +12,7 @@ from functools import partial, update_wrapper, wraps\n from inspect import getfullargspec\n from itertools import chain\n \n+from django.utils.inspect import getargspec\n \n WRAPPER_ASSIGNMENTS = ('__module__', '__name__', '__qualname__', '__doc__',\n                        '__annotations__')\n@@ -84,6 +85,7 @@ def method_decorator(decorator, name=''):\n             'method_decorator() doesn\\'t support keyword arguments when using a '\n             'single callable.'\n         )\n+    @wraps(decorator)\n     def _dec(func):\n         def _wrapper(self, *args, **kwargs):\n             @decorator\n@@ -91,6 +93,7 @@ def method_decorator(decorator, name=''):\n                 return func(self, *args, **kwargs)\n             bound_func = bound_method.__get__(self, self.__class__)\n             return bound_func(*args, **kwargs)\n+        update_wrapper(_wrapper, func)\n         return _wrapper\n \n     if name:\n@@ -102,6 +105,7 @@ def method_decorator(decorator, name=''):\n         def _dec(cls):\n             for name in names:\n                 if hasattr(cls, name):\n+                    update_wrapper(getattr(cls, name), getattr(cls, name).__func__)\n                     setattr(cls, name, decorator(getattr(cls, name)))\n             return cls\n         return _dec",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12589",
    "model_patch": "diff --git a/django/db/models/sql/compiler.py b/django/db/models/sql/compiler.py\nindex abc1234..def5678 100644\n--- a/django/db/models/sql/compiler.py\n+++ b/django/db/models/sql/compiler.py\n@@ -1230,7 +1230,10 @@ class SQLCompiler:\n             if not isinstance(col, (list, tuple)):\n                 col = [col]\n             for c in col:\n-                group_by.append(self.compile(c))\n+                if hasattr(c, 'contains_aggregate') and c.contains_aggregate:\n+                    group_by.append(self.compile(c))\n+                else:\n+                    group_by.append(self.compile(c))\n         return group_by\n \n     def get_order_by(self):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15781",
    "model_patch": "diff --git a/django/core/management/base.py b/django/core/management/base.py\nindex abc1234..def5678 100644\n--- a/django/core/management/base.py\n+++ b/django/core/management/base.py\n@@ -100,6 +100,8 @@ class CommandParser(argparse.ArgumentParser):\n         else:\n             self._style = color_style(force_color)\n             self._colored_errors = False\n+        # Preserve newlines in help text\n+        self.formatter_class = argparse.RawDescriptionHelpFormatter\n \n     def parse_args(self, args=None, namespace=None):\n         # Catch missing argument for a better error message\n@@ -273,7 +275,7 @@ class BaseCommand:\n         parser = CommandParser(\n             prog='%s %s' % (os.path.basename(prog_name), subcommand),\n             description=self.help or None,\n-            formatter_class=DjangoHelpFormatter,\n+            formatter_class=argparse.RawDescriptionHelpFormatter,\n             missing_args_message=getattr(self, 'missing_args_message', None),\n             called_from_command_line=getattr(self, '_called_from_command_line', None),\n         )",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14752",
    "model_patch": "diff --git a/django/contrib/admin/views/autocomplete.py b/django/contrib/admin/views/autocomplete.py\nindex 1234567..89abcde 100644\n--- a/django/contrib/admin/views/autocomplete.py\n+++ b/django/contrib/admin/views/autocomplete.py\n@@ -47,6 +47,11 @@ class AutocompleteJsonView(View):\n             raise PermissionDenied\n \n         self.object_list = self.get_queryset()\n+        context = self.get_context_data()\n         return JsonResponse({\n-            'results': [{'id': str(getattr(obj, to_field_name)), 'text': str(obj)} for obj in context['object_list']],\n+            'results': [\n+                self.serialize_result(obj, to_field_name)\n+                for obj in context['object_list']\n+            ],\n             'pagination': {'more': context['page_obj'].has_next()},\n         })\n+\n+    def serialize_result(self, obj, to_field_name):\n+        return {'id': str(getattr(obj, to_field_name)), 'text': str(obj)}",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13447",
    "model_patch": "diff --git a/django/contrib/admin/sites.py b/django/contrib/admin/sites.py\nindex 5f8d7e3..2e4b1a7 100644\n--- a/django/contrib/admin/sites.py\n+++ b/django/contrib/admin/sites.py\n@@ -371,7 +371,7 @@ class AdminSite:\n         \"\"\"\n         return request.user.has_perm(perm)\n \n-    def _build_app_dict(self, request, label=None):\n+    def build_app_dict(self, request, label=None):\n         \"\"\"\n         Build the app dictionary. The optional `label` parameter filters models\n         of a specific app.\n@@ -394,6 +394,7 @@ class AdminSite:\n                         'name': capfirst(model._meta.verbose_name_plural),\n                         'object_name': model._meta.object_name,\n                         'perms': perms,\n+                        'model': model,\n                     })\n                 if model_dict:\n                     app_dict = {\n@@ -550,7 +551,7 @@ class AdminSite:\n         if app_list is None:\n             app_list = []\n \n-            for app_dict in self._build_app_dict(request).values():\n+            for app_dict in self.build_app_dict(request).values():\n                 app_label = app_dict['app_label']\n                 app_dict['name'] = apps.get_app_config(app_label).verbose_name\n                 app_list.append(app_dict)\n@@ -578,7 +579,7 @@ class AdminSite:\n         app_label = app_label.lower()\n \n         try:\n-            app_dict = self._build_app_dict(request, app_label)[app_label]\n+            app_dict = self.build_app_dict(request, app_label)[app_label]\n         except KeyError:\n             raise Http404('The requested admin page does not exist.')",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12908",
    "model_patch": "diff --git a/django/db/models/sql/compiler.py b/django/db/models/sql/compiler.py\nindex abc1234..def5678 100644\n--- a/django/db/models/sql/compiler.py\n+++ b/django/db/models/sql/compiler.py\n@@ -400,6 +400,12 @@ class SQLCompiler:\n             distinct_fields = self.get_distinct()\n             if distinct_fields:\n                 result.append('DISTINCT ON (%s)' % ', '.join(distinct_fields))\n+                # When this is a UNION query, we need to wrap the entire query\n+                # to apply DISTINCT ON to the UNION results\n+                if (hasattr(self.query, 'combinator') and \n+                    self.query.combinator == 'UNION'):\n+                    result.insert(0, 'SELECT ')\n+                    return '(' + ' '.join(result) + ')'\n             elif self.query.distinct:\n                 result.append('DISTINCT')\n         return ' '.join(result)\n@@ -409,7 +415,11 @@ class SQLCompiler:\n         distinct_fields = self.get_distinct()\n         if distinct_fields:\n             return [\n                 'DISTINCT ON (%s)' % ', '.join(distinct_fields),\n-                ' '.join(result),\n+                # Wrap UNION queries to apply DISTINCT ON to combined results\n+                '(' + ' '.join(result) + ')' if (\n+                    hasattr(self.query, 'combinator') and \n+                    self.query.combinator == 'UNION'\n+                ) else ' '.join(result),\n             ]\n         elif self.query.distinct:\n             return ['DISTINCT'] + result",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-6938",
    "model_patch": "diff --git a/astropy/io/fits/fitsrec.py b/astropy/io/fits/fitsrec.py\nindex e69de29..a5c3f8d 100644\n--- a/astropy/io/fits/fitsrec.py\n+++ b/astropy/io/fits/fitsrec.py\n@@ -XXX,XX +XXX,XX @@  # Replace exponent separator in floating point numbers\n         if 'D' in format:\n-            output_field.replace(encode_ascii('E'), encode_ascii('D'))\n+            output_field = output_field.replace(encode_ascii('E'), encode_ascii('D'))",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11179",
    "model_patch": "diff --git a/django/db/models/deletion.py b/django/db/models/deletion.py\n--- a/django/db/models/deletion.py\n+++ b/django/db/models/deletion.py\n@@ -277,6 +277,8 @@\n             for model, instances in self.data.items():\n                 query = sql.DeleteQuery(model)\n                 pk_list = [obj.pk for obj in instances]\n                 query.delete_batch(pk_list, self.using)\n+                for obj in instances:\n+                    obj.pk = None\n         else:\n             # fast deletes\n             for qs in self.fast_deletes:",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13158",
    "model_patch": "diff --git a/django/db/models/query.py b/django/db/models/query.py\nindex 7e1c6d9..3f4a2b8 100644\n--- a/django/db/models/query.py\n+++ b/django/db/models/query.py\n@@ -1000,6 +1000,8 @@ class QuerySet:\n         \"\"\"\n         clone = self._chain()\n         clone.query.combinator = 'union'\n+        if self.query.is_empty():\n+            clone.query.set_empty()\n         clone.query.combinator_all = all\n         for qs in other_qs:\n             clone.query.combine(qs.query, connector)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14411",
    "model_patch": "diff --git a/django/contrib/auth/forms.py b/django/contrib/auth/forms.py\nindex 7c9f123..4b8f567 100644\n--- a/django/contrib/auth/forms.py\n+++ b/django/contrib/auth/forms.py\n@@ -97,7 +97,7 @@ class ReadOnlyPasswordHashWidget(forms.Widget):\n \n     def render(self, name, value, attrs=None, renderer=None):\n         encoded = value\n-        final_attrs = self.build_attrs(attrs)\n+        final_attrs = self.build_attrs(attrs, id=None)  # Remove 'id' to avoid 'for' attribute in label\n \n         if not encoded or encoded.startswith(UNUSABLE_PASSWORD_PREFIX):\n             summary = mark_safe(\"<strong>%s</strong>\" % gettext(\"No password set.\"))",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11905",
    "model_patch": "diff --git a/django/db/models/lookups.py b/django/db/models/lookups.py\nindex 1234567..89abcde 100644\n--- a/django/db/models/lookups.py\n+++ b/django/db/models/lookups.py\n@@ -242,6 +242,8 @@ class IsNull(BuiltinLookup):\n     lookup_name = 'isnull'\n \n     def get_prep_lookup(self):\n+        if not isinstance(self.rhs, bool):\n+            raise ValueError('The QuerySet value for an isnull lookup must be True or False.')\n         if self.rhs:\n             return self.get_db_prep_lookup(None, self.connection)\n         return self.get_db_prep_lookup(self.lhs.output_field.get_prep_value(None), self.connection)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12286",
    "model_patch": "diff --git a/django/core/checks/translation.py b/django/core/checks/translation.py\nindex 6d1f2a8..e4b3c2f 100644\n--- a/django/core/checks/translation.py\n+++ b/django/core/checks/translation.py\n@@ -1,4 +1,5 @@\n from django.conf import settings\n+from django.utils.translation import to_language\n from django.core.checks import Error, register\n \n \n@@ -10,7 +11,10 @@ def check_setting_language_code(app_configs, **kwargs):\n     \"\"\"\n     if not settings.LANGUAGES:\n         return []\n-    if settings.LANGUAGE_CODE not in {lang[0] for lang in settings.LANGUAGES}:\n+    language_codes = {lang[0] for lang in settings.LANGUAGES}\n+    if (settings.LANGUAGE_CODE not in language_codes and\n+            to_language(settings.LANGUAGE_CODE) not in language_codes):\n         return [Error(\n             \"You have provided a value for the LANGUAGE_CODE setting that is not \"\n-            \"in the LANGUAGES setting.\", id=\"translation.E004\",\n+            \"in the LANGUAGES setting, nor is the base language available.\", id=\"translation.E004\",\n         )]\n     return []",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13925",
    "model_patch": "diff --git a/django/db/models/options.py b/django/db/models/options.py\nindex abc1234..def5678 100644\n--- a/django/db/models/options.py\n+++ b/django/db/models/options.py\n@@ -200,6 +200,9 @@ class Options:\n         if self.pk is None:\n             if self.parents:\n                 # Promote the first parent link's primary key to pk\n+                if any(parent._meta.auto_field is not None for parent in self.parents):\n+                    # Skip auto-created pk warning if parent has explicit pk\n+                    return\n                 for parent in self.parents:\n                     field = self.parents[parent]\n                     if field.primary_key:\ndiff --git a/django/db/models/base.py b/django/db/models/base.py\nindex xyz7890..uvw1234 100644\n--- a/django/db/models/base.py\n+++ b/django/db/models/base.py\n@@ -300,6 +300,10 @@ class Model(metaclass=ModelBase):\n             # Ensure the primary key is a field for the parent model.\n             if base._meta.pk is None and base._meta.parents:\n                 base._meta.pk = next(iter(base._meta.parents.values()))\n+                # Mark the inherited PK as not auto-created\n+                if hasattr(base._meta.pk, 'auto_created'):\n+                    base._meta.pk.auto_created = False\n+                base._meta.auto_field = None\n \n     def __init__(self, *args, **kwargs):\n         # Alias some things as locals to avoid repeat global lookups",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11133",
    "model_patch": "diff --git a/django/http/response.py b/django/http/response.py\nindex 5e8f0b1..a7c3b2d 100644\n--- a/django/http/response.py\n+++ b/django/http/response.py\n@@ -123,6 +123,8 @@ class HttpResponse(HttpResponseBase):\n     def _convert_to_bytes(self, value):\n         if isinstance(value, str):\n             return bytes(value.encode(self.charset))\n+        elif isinstance(value, memoryview):\n+            return value.tobytes()\n         elif isinstance(value, bytes):\n             return value\n         return bytes(force_str(value).encode(self.charset))",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14995",
    "model_patch": "diff --git a/astropy/nddata/mixins/ndarithmetic.py b/astropy/nddata/mixins/ndarithmetic.py\nindex abc1234..def5678 100644\n--- a/astropy/nddata/mixins/ndarithmetic.py\n+++ b/astropy/nddata/mixins/ndarithmetic.py\n@@ -123,10 +123,10 @@ def _prepare_mask(self, operand, handle_mask, axis=None):\n             return None\n         \n         if handle_mask is np.bitwise_or:\n-            if mask is None:\n-                mask = np.zeros(self.shape, dtype=bool)\n-            if operand_mask is None:\n-                operand_mask = np.zeros(operand.shape, dtype=bool)\n+            if mask is None:\n+                return operand_mask\n+            if operand_mask is None:\n+                return mask\n             return handle_mask(mask, operand_mask)\n         # ... other mask handling cases ...",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12915",
    "model_patch": "diff --git a/django/contrib/staticfiles/handlers.py b/django/contrib/staticfiles/handlers.py\nindex abc1234..def5678 100644\n--- a/django/contrib/staticfiles/handlers.py\n+++ b/django/contrib/staticfiles/handlers.py\n@@ -65,6 +65,9 @@ class StaticFilesHandlerMixin:\n     def get_response(self, request):\n         return self.serve(request)\n \n+    async def get_response_async(self, request):\n+        return await sync_to_async(self.serve)(request)\n+\n     def serve(self, request):\n         path = self.file_path(request.path)\n         if not os.path.exists(path):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13315",
    "model_patch": "diff --git a/django/forms/models.py b/django/forms/models.py\nindex 9f3d2e1..6c8a2f4 100644\n--- a/django/forms/models.py\n+++ b/django/forms/models.py\n@@ -1135,7 +1135,7 @@ class ModelChoiceField(ChoiceField):\n     def _get_choices(self):\n         if hasattr(self, '_choices'):\n             return self._choices\n-        return self.queryset.all()\n+        return self.queryset.distinct()\n \n     choices = property(_get_choices, ChoiceField._set_choices)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15388",
    "model_patch": "diff --git a/django/conf/project_template/project_name/settings.py-tpl b/django/conf/project_template/project_name/settings.py-tpl\nindex abc1234..def5678 100644\n--- a/django/conf/project_template/project_name/settings.py-tpl\n+++ b/django/conf/project_template/project_name/settings.py-tpl\n@@ -54,7 +54,7 @@\n TEMPLATES = [\n     {\n         'BACKEND': 'django.template.backends.django.DjangoTemplates',\n-        'DIRS': [],\n+        'DIRS': [BASE_DIR / 'templates'],\n         'APP_DIRS': True,\n         'OPTIONS': {\n             'context_processors': [",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12113",
    "model_patch": "diff --git a/tests/admin_views/test_multidb.py b/tests/admin_views/test_multidb.py\nindex abc1234..def5678 100644\n--- a/tests/admin_views/test_multidb.py\n+++ b/tests/admin_views/test_multidb.py\n@@ -15,9 +15,15 @@ DATABASES = {\n     'default': {\n         'ENGINE': 'django.db.backends.sqlite3',\n+        'TEST': {\n+            'NAME': ':memory:',\n+            'OPTIONS': {'timeout': 30},\n+        },\n     },\n     'other': {\n         'ENGINE': 'django.db.backends.sqlite3',\n+        'TEST': {\n+            'NAME': ':memory:',\n+            'OPTIONS': {'timeout': 30},\n+        },\n     }\n }",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15213",
    "model_patch": "diff --git a/django/db/models/expressions.py b/django/db/models/expressions.py\nindex 4f8e2d1..6b7c3e2 100644\n--- a/django/db/models/expressions.py\n+++ b/django/db/models/expressions.py\n@@ -234,7 +234,10 @@ class ExpressionWrapper(Expression):\n         sql, params = compiler.compile(self.expression)\n         if not sql:\n             # Use a default value for empty expressions.\n-            sql = '0'\n+            if isinstance(self.expression, Q) and self.expression.negated and not self.expression.children:\n+                sql = '1'\n+            else:\n+                sql = '0'\n         return sql, params\n \n     def get_group_by_cols(self, alias=None):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14017",
    "model_patch": "diff --git a/django/db/models/query_utils.py b/django/db/models/query_utils.py\nindex 3e2f6b8..5a4d9e3 100644\n--- a/django/db/models/query_utils.py\n+++ b/django/db/models/query_utils.py\n@@ -89,6 +89,9 @@ class Q:\n     def __and__(self, other):\n         return self._combine(other, self.AND)\n \n+    def __rand__(self, other):\n+        return self._combine(other, self.AND)\n+\n     def __invert__(self):\n         obj = type(self)()\n         obj.add(self, self.NOT)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15202",
    "model_patch": "diff --git a/django/core/validators.py b/django/core/validators.py\nindex 5e3b1a2..d4f9c3b 100644\n--- a/django/core/validators.py\n+++ b/django/core/validators.py\n@@ -127,7 +127,7 @@ class URLValidator(RegexValidator):\n             value = iri_to_uri(value)\n         try:\n             splitted_url = urlsplit(value)\n-        except ValueError:\n+        except ValueError as e:\n             raise ValidationError(self.message, code=self.code)\n         if splitted_url.hostname and len(splitted_url.hostname) > 253:\n             raise ValidationError(self.message, code=self.code)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14155",
    "model_patch": "diff --git a/django/urls/resolvers.py b/django/urls/resolvers.py\nindex abc1234..def5678 100644\n--- a/django/urls/resolvers.py\n+++ b/django/urls/resolvers.py\n@@ -1,5 +1,6 @@\n import inspect\n import re\n+import functools\n from threading import local\n \n from django.conf import settings\n@@ -257,6 +258,8 @@ class ResolverMatch:\n         self.args = args\n         self.kwargs = kwargs\n         self.url_name = url_name\n+        if isinstance(func, functools.partial):\n+            func = func.func\n         self.func = func\n         self._func_path = get_callable_name(func)\n         self.app_name = app_name\n\ndiff --git a/tests/urlresolvers/tests.py b/tests/urlresolvers/tests.py\nindex xyz1234..uvw5678 100644\n--- a/tests/urlresolvers/tests.py\n+++ b/tests/urlresolvers/tests.py\n@@ -1,5 +1,6 @@\n import unittest\n from unittest import mock\n+import functools\n \n from django.conf.urls import url\n from django.core.exceptions import ImproperlyConfigured\n@@ -8,6 +9,7 @@ from django.http import HttpResponse\n from django.test import SimpleTestCase, override_settings\n from django.urls import clear_url_caches, get_resolver, get_urlconf, resolve, reverse\n from django.urls.resolvers import RegexPattern, RoutePattern, URLResolver\n+from django.urls.resolvers import ResolverMatch\n \n \n def test_view(request):\n@@ -15,6 +17,9 @@ def test_view(request):\n     return HttpResponse('test view')\n \n \n+def partial_view(request, arg1, arg2):\n+    return HttpResponse(f'partial view: {arg1}-{arg2}')\n+\n class URLResolverTests(SimpleTestCase):\n \n     def setUp(self):\n@@ -22,6 +27,13 @@ class URLResolverTests(SimpleTestCase):\n         clear_url_caches()\n         self._old_root_urlconf = settings.ROOT_URLCONF\n \n+    def test_resolver_match_with_partial(self):\n+        partial_func = functools.partial(partial_view, arg1='foo', arg2='bar')\n+        match = ResolverMatch(partial_func, (), {}, 'test-url')\n+        self.assertIn('partial_view', repr(match))\n+        self.assertNotIn('functools.partial', repr(match))\n+        self.assertEqual(match.func, partial_view)\n+\n     @override_settings(ROOT_URLCONF='urlpatterns_reverse.tests.urls')\n     def test_resolve_to_name(self):\n         resolver = get_resolver()",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11999",
    "model_patch": "diff --git a/django/db/models/fields/__init__.py b/django/db/models/fields/__init__.py\nindex 0a1b2c3..4d5e6f7 100644\n--- a/django/db/models/fields/__init__.py\n+++ b/django/db/models/fields/__init__.py\n@@ -762,6 +762,9 @@ class Field(RegisterLookupMixin):\n \n     def get_display_value(self, instance):\n         value = getattr(instance, self.attname)\n+        method_name = 'get_%s_display' % self.name\n+        if hasattr(instance, method_name):\n+            return getattr(instance, method_name)()\n         return self.value_to_string(instance)\n \n     def value_to_string(self, obj):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15347",
    "model_patch": "diff --git a/django/contrib/messages/storage/base.py b/django/contrib/messages/storage/base.py\nindex 1234567..89abcde 100644\n--- a/django/contrib/messages/storage/base.py\n+++ b/django/contrib/messages/storage/base.py\n@@ -1,5 +1,5 @@\n class Message:\n     def __init__(self, level, message, extra_tags=None):\n-        self.extra_tags = extra_tags or None\n+        self.extra_tags = extra_tags if extra_tags is not None else None\n         # Other initializations...\n\ndiff --git a/django/contrib/messages/storage/cookie.py b/django/contrib/messages/storage/cookie.py\nindex 2345678..9abcdef 100644\n--- a/django/contrib/messages/storage/cookie.py\n+++ b/django/contrib/messages/storage/cookie.py\n@@ -1,6 +1,6 @@\n class MessageEncoder(json.JSONEncoder):\n     def default(self, obj):\n         if isinstance(obj, Message):\n-            return {'message': obj.message, 'extra_tags': obj.extra_tags or None}\n+            return {'message': obj.message, 'extra_tags': obj.extra_tags if obj.extra_tags is not None else None}\n         return super().default(obj)\n\n class MessageDecoder(json.JSONDecoder):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13321",
    "model_patch": "diff --git a/django/contrib/sessions/backends/base.py b/django/contrib/sessions/backends/base.py\nindex abc1234..def5678 100644\n--- a/django/contrib/sessions/backends/base.py\n+++ b/django/contrib/sessions/backends/base.py\n@@ -123,7 +123,10 @@ def _legacy_decode(self, session_data):\n         # support for salted session data.\n         try:\n             # RemovedInDjango40Warning: when the deprecation ends, replace with:\n-            encoded_data = base64.b64decode(session_data.encode('ascii'))\n+            try:\n+                encoded_data = base64.b64decode(session_data.encode('ascii'))\n+            except (binascii.Error, UnicodeError):\n+                return {}\n             try:\n                 hash, serialized = encoded_data.split(b':', 1)\n                 return self.serializer().loads(serialized)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12983",
    "model_patch": "diff --git a/django/utils/text.py b/django/utils/text.py\nindex abc1234..def5678 100644\n--- a/django/utils/text.py\n+++ b/django/utils/text.py\n@@ -398,6 +398,7 @@ def slugify(value, allow_unicode=False):\n     trailing whitespace, dashes, and underscores.\n     \"\"\"\n     value = str(value)\n+    value = value.strip('-_')\n     if allow_unicode:\n         value = unicodedata.normalize('NFKC', value)\n     else:",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11099",
    "model_patch": "diff --git a/django/contrib/auth/validators.py b/django/contrib/auth/validators.py\nindex 5f6d3c3..c7f5e8a 100644\n--- a/django/contrib/auth/validators.py\n+++ b/django/contrib/auth/validators.py\n@@ -6,7 +6,7 @@ class ASCIIUsernameValidator:\n     def __init__(self, message=None, code=None):\n         self.message = message or _('Enter a valid username. This value may contain only letters, '\n                                     'numbers, and @/./+/-/_ characters.')\n-        self.regex = r'^[\\w.@+-]+$'\n+        self.regex = r'\\A[\\w.@+-]+\\Z'\n         self.code = code or 'invalid'\n \n     def __call__(self, value):\n@@ -26,7 +26,7 @@ class UnicodeUsernameValidator:\n     def __init__(self, message=None, code=None):\n         self.message = message or _('Enter a valid username. This value may contain only letters, '\n                                     'numbers, and @/./+/-/_ characters.')\n-        self.regex = r'^[\\w.@+-]+$'\n+        self.regex = r'\\A[\\w.@+-]+\\Z'\n         self.code = code or 'invalid'\n \n     def __call__(self, value):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14365",
    "model_patch": "diff --git a/astropy/io/ascii/qdp.py b/astropy/io/ascii/qdp.py\nindex 8b7e9f5..d4a3c2b 100644\n--- a/astropy/io/ascii/qdp.py\n+++ b/astropy/io/ascii/qdp.py\n@@ -88,7 +88,7 @@ class QDPTables:\n     \"\"\"\n \n     def __init__(self, lines):\n-        self.lines = lines\n+        self.lines = [line.upper() if not line.lstrip().startswith(('!', '#')) else line for line in lines]\n         self.commands = []\n         self.comments = []\n         self.rows = []",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13933",
    "model_patch": "diff --git a/django/forms/models.py b/django/forms/models.py\nindex 1234567..89abcde 100644\n--- a/django/forms/models.py\n+++ b/django/forms/models.py\n@@ -743,7 +743,7 @@ class ModelChoiceField(ChoiceField):\n     # This class is a subclass of ChoiceField for purity, but it doesn't\n     # actually use any of ChoiceField's implementation.\n     default_error_messages = {\n-        'invalid_choice': _('Select a valid choice. That choice is not one of'\n+        'invalid_choice': _('Select a valid choice. %(value)s is not one of'\n                             ' the available choices.'),\n     }",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12284",
    "model_patch": "diff --git a/django/db/models/fields/__init__.py b/django/db/models/fields/__init__.py\nindex xyz7890..uvw1234 100644\n--- a/django/db/models/fields/__init__.py\n+++ b/django/db/models/fields/__init__.py\n@@ -732,6 +732,8 @@ class Field(RegisterLookupMixin):\n     def flatchoices(self):\n         \"\"\"Flattened version of choices tuple.\"\"\"\n         if self._flatchoices is None:\n+            if hasattr(self, 'choices') and callable(self.choices):\n+                self._flatchoices = self.get_choices(include_blank=False)\n             choices = list(self.choices)\n             self._flatchoices = []\n             for choice, value in choices:",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11848",
    "model_patch": "diff --git a/django/utils/http.py b/django/utils/http.py\nindex 1234567..89abcde 100644\n--- a/django/utils/http.py\n+++ b/django/utils/http.py\n@@ -1,5 +1,6 @@\n import calendar\n import datetime\n+import time\n import email.utils\n \n from django.utils.regex_helper import _lazy_re_compile\n@@ -40,6 +41,24 @@ def http_date(epoch_seconds=None):\n     return email.utils.formatdate(epoch_seconds, usegmt=True)\n \n \n+def parse_http_date(date):\n+    # Parse the date string using email.utils.parsedate_tz.\n+    parsed_date = email.utils.parsedate_tz(date)\n+    if parsed_date is None:\n+        raise ValueError(f\"'{date}' is not a valid HTTP date\")\n+\n+    year = parsed_date[0] % 100\n+    current_year = time.gmtime().tm_year % 100\n+\n+    if year > current_year + 50:\n+        year += 1900\n+    else:\n+        year += 2000\n+\n+    month = parsed_date[1]\n+    day = parsed_date[2]\n+\n+\n def parse_http_date_safe(date):\n     \"\"\"\n     Same as parse_http_date, but returns None if the input is invalid.",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14534",
    "model_patch": "diff --git a/django/forms/boundfield.py b/django/forms/boundfield.py\nindex 1234567..89abcde 100644\n--- a/django/forms/boundfield.py\n+++ b/django/forms/boundfield.py\n@@ -1,6 +1,6 @@\n class BoundWidget:\n     ...\n-    def id_for_label(self):\n-        return 'id_%s_%s' % (self.data['name'], self.data['index'])\n+    def id_for_label(self):\n+        return self.data['attrs']['id']",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13220",
    "model_patch": "diff --git a/django/core/exceptions.py b/django/core/exceptions.py\nindex 6bcbf0e..d4f5f8a 100644\n--- a/django/core/exceptions.py\n+++ b/django/core/exceptions.py\n@@ -141,6 +141,26 @@ class ValidationError(Exception):\n             return dict(self)\n         return list(self)\n \n+    def __eq__(self, other):\n+        if not isinstance(other, ValidationError):\n+            return NotImplemented\n+\n+        if hasattr(self, 'error_dict'):\n+            if not hasattr(other, 'error_dict'):\n+                return False\n+            if set(self.error_dict.keys()) != set(other.error_dict.keys()):\n+                return False\n+            for key in self.error_dict:\n+                if set(self.error_dict[key]) != set(other.error_dict[key]):\n+                    return False\n+            return True\n+\n+        return set(self.messages) == set(other.messages)\n+\n     def __repr__(self):\n         if hasattr(self, 'error_dict'):\n             return 'ValidationError(%s)' % repr(self.error_dict)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13964",
    "model_patch": "diff --git a/django/db/models/fields/related_descriptors.py b/django/db/models/fields/related_descriptors.py\nindex 6f9c8d1..e4b3f2a 100644\n--- a/django/db/models/fields/related_descriptors.py\n+++ b/django/db/models/fields/related_descriptors.py\n@@ -172,6 +172,11 @@ class ForwardManyToOneDescriptor(ForwardManyToOneDescriptorBase):\n                     # Assign by primary key if possible, to avoid a database\n                     # hit.\n                     rel_obj = self.field.remote_field.model._default_manager.get(pk=rel_obj)\n+                else:\n+                    # If the related object has no primary key set (non-auto PK),\n+                    # ensure the parent object's foreign key is updated when the\n+                    # primary key is set on the related object.\n+                    rel_obj._state.adding = False\n \n             # Set the value of the related field.\n             setattr(instance, self.cache_name, rel_obj)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15320",
    "model_patch": "diff --git a/django/db/models/expressions.py b/django/db/models/expressions.py\nindex 3c1b2d5..e4f6a8b 100644\n--- a/django/db/models/expressions.py\n+++ b/django/db/models/expressions.py\n@@ -1209,6 +1209,7 @@ class Subquery(BaseExpression):\n         template='(%(subquery)s)',\n     ):\n         self.query = query\n+        self.query.subquery = True\n         self.template = template\n         self.output_field = output_field\n         self.extra = extra or {}",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12184",
    "model_patch": "diff --git a/urls.py b/urls.py\nindex e69de29..c3f4e8a 100644\n--- a/urls.py\n+++ b/urls.py\n@@ -1,5 +1,5 @@\n urlpatterns += [\n     ...\n-    re_path(r'^module/(?P<format>(html|json|xml))?/?$', views.modules, name='modules'),\n+    re_path(r'^module(?:/(?P<format>html|json|xml))?/?$', views.modules, name='modules'),\n ]",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11964",
    "model_patch": "diff --git a/django/db/models/base.py b/django/db/models/base.py\nindex abc1234..def5678 100644\n--- a/django/db/models/base.py\n+++ b/django/db/models/base.py\n@@ -500,6 +500,8 @@ class Model(metaclass=ModelBase):\n             if isinstance(value, enum.Enum):\n                 value = value.value\n             setattr(self, attr, value)\n+        elif isinstance(value, enum.Enum):\n+            value = value.value\n         self.__dict__[field.attname] = value\n \n     def delete(self, using=None, keep_parents=False):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14238",
    "model_patch": "diff --git a/django/db/models/fields/__init__.py b/django/db/models/fields/__init__.py\nindex 3f8e2b1..a9b3f17 100644\n--- a/django/db/models/fields/__init__.py\n+++ b/django/db/models/fields/__init__.py\n@@ -2271,7 +2271,7 @@ class AutoFieldMeta(type):\n     def __subclasscheck__(self, subclass):\n-        return super().__subclasscheck__(subclass) or subclass in self._subclasses\n+        return super().__subclasscheck__(subclass) or issubclass(subclass, tuple(self._subclasses))\n \n     @property\n     def _subclasses(self):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15061",
    "model_patch": "diff --git a/django/forms/widgets.py b/django/forms/widgets.py\nindex 3e6d8c4..f7b9a3d 100644\n--- a/django/forms/widgets.py\n+++ b/django/forms/widgets.py\n@@ -530,11 +530,6 @@ class MultiWidget(Widget):\n     def decompress(self, value):\n         raise NotImplementedError('Subclasses must implement this method.')\n \n-    def id_for_label(self, id_):\n-        if id_:\n-            id_ += '0'\n-        return id_\n-\n     def value_from_datadict(self, data, files, name):\n         return [\n             widget.value_from_datadict(data, files, '%s_%s' % (name, i))",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15498",
    "model_patch": "diff --git a/django/utils/http.py b/django/utils/http.py\nindex 9f3e5d2..e6b7c4a 100644\n--- a/django/utils/http.py\n+++ b/django/utils/http.py\n@@ -135,6 +135,9 @@ def parse_http_date(date):\n     The three formats allowed by the RFC are accepted, even if only the first\n     one is still in widespread use.\n \n+    Return None if the date is an empty string.\n+\n     Return an integer representing the number of seconds since the epoch.\n     \"\"\"\n+    if not date:\n+        return None\n     try:\n         year = int(date[12:16])\n         month = MONTHS.index(date[8:11].title()) + 1",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13230",
    "model_patch": "diff --git a/django/contrib/syndication/views.py b/django/contrib/syndication/views.py\nindex 8b3d2b9..e4f0c4e 100644\n--- a/django/contrib/syndication/views.py\n+++ b/django/contrib/syndication/views.py\n@@ -210,7 +210,9 @@ def add_item(self, title, link, description, author_email=None,\n         'description': description,\n         'link': link,\n     }\n-    if item_extra_kwargs:\n+    if comments is not None:\n+        item['item_comments'] = comments\n+    if item_extra_kwargs:\n         item.update(item_extra_kwargs)\n     self.items.append(item)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13028",
    "model_patch": "diff --git a/django/db/models/sql/query.py b/django/db/models/sql/query.py\nindex 1a2b3c4..5d6e7f8 100644\n--- a/django/db/models/sql/query.py\n+++ b/django/db/models/sql/query.py\n@@ -1128,7 +1128,11 @@ class Query(BaseExpression):\n \n     def check_filterable(self, value):\n         if hasattr(value, 'filterable'):\n-            if not value.filterable:\n+            # Only apply filterable check to non-model instances\n+            from django.db.models import Model\n+            if isinstance(value, Model):\n+                return\n+            elif not value.filterable:\n                 raise NotSupportedError(\n                     \"Cannot filter against a non-filterable object.\"\n                 )",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14182",
    "model_patch": "diff --git a/astropy/io/ascii/rst.py b/astropy/io/ascii/rst.py\nindex 1234567..89abcde 100644\n--- a/astropy/io/ascii/rst.py\n+++ b/astropy/io/ascii/rst.py\n@@ -15,7 +15,8 @@ class RST(astropy.io.ascii.core.BaseReader):\n class RST(astropy.io.ascii.core.BaseWriter):\n     \"\"\"Write the `astropy.io.ascii` format table as RestructuredText.\"\"\"\n \n-    def __init__(self):\n+    def __init__(self, header_rows=['name']):\n+        self.header_rows = header_rows\n         super().__init__()\n \n     def _format_table(self):\n@@ -38,6 +39,9 @@ class RST(astropy.io.ascii.core.BaseWriter):\n \n         cols = list(self.cols.values())\n         n_cols = len(cols)\n+\n+        if len(self.header_rows) > 1:\n+            raise ValueError('RST format only supports one header row')\n \n         # Get the column names and units as a list of lists. This is returned as a\n         # list of rows where each element is a list of column values for that row.\n@@ -45,7 +49,7 @@ class RST(astropy.io.ascii.core.BaseWriter):\n         # For RST format the header is just the column names, but we use the full\n         # _get_col_str_iters() machinery to deal with the general case of\n         # multiline column names.\n-        col_str_iters = self._get_col_str_iters(['name'])\n+        col_str_iters = self._get_col_str_iters(self.header_rows)\n \n         # Get the first line of the header (column names)\n         col_strs = [next(x) for x in col_str_iters]",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11049",
    "model_patch": "diff --git a/django/forms/fields.py b/django/forms/fields.py\nindex abc1234..def5678 100644\n--- a/django/forms/fields.py\n+++ b/django/forms/fields.py\n@@ -XXX,XX +XXX,XX @@ class DurationField(Field):\n     default_error_messages = {\n         'invalid': _('Enter a valid duration.'),\n     }\n+    default_help_text = _('Format: [DD] [[HH:]MM:]ss[.uuuuuu]')\n \n     def prepare_value(self, value):\n         if isinstance(value, datetime.timedelta):\n@@ -XXX,XX +XXX,XX @@ class DurationField(Field):\n             parsed = parse_duration(value)\n         except ValueError:\n             raise ValidationError(\n-                self.error_messages['invalid'], code='invalid',\n-                params={'value': value, 'format': '[DD] [HH:[MM:]]ss[.uuuuuu]'},\n+                self.error_messages['invalid'],\n+                code='invalid',\n+                params={'value': value, 'format': '[DD] [[HH:]MM:]ss[.uuuuuu]'},\n             )\n         if parsed is None:\n             raise ValidationError(",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-12907",
    "model_patch": "diff --git a/astropy/modeling/separable.py b/astropy/modeling/separable.py\nindex abc1234..def5678 100644\n--- a/astropy/modeling/separable.py\n+++ b/astropy/modeling/separable.py\n@@ -21,7 +21,7 @@\n \n __all__ = ['separability_matrix']\n \n-def separability_matrix(model):\n+def separability_matrix(model, _nested_call=False):\n     \"\"\"\n     Compute the separability matrix for a given model.\n \n@@ -35,6 +35,9 @@ def separability_matrix(model):\n     model : `~astropy.modeling.Model`\n         The model for which the separability matrix is to be computed.\n \n+    _nested_call : bool, optional\n+        Internal flag indicating if this is a recursive call from a compound model.\n+\n     Returns\n     -------\n     separable : `~numpy.ndarray`\n@@ -47,6 +50,9 @@ def separability_matrix(model):\n     if model.separable:\n         return np.identity(model.n_outputs, dtype=bool)\n \n+    if hasattr(model, '_calculate_separability_matrix'):\n+        return model._calculate_separability_matrix()\n+\n     separable = np.zeros((model.n_outputs, model.n_inputs), dtype=bool)\n     inputs = np.zeros(model.n_inputs)\n     delta = np.zeros(model.n_inputs)\n@@ -61,4 +67,4 @@ def separability_matrix(model):\n                 separable[i, j] = np.allclose(output1, output2)\n             delta[j] = 0.0\n \n-    return separable\n+    return separable",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11039",
    "model_patch": "diff --git a/django/core/management/commands/sqlmigrate.py b/django/core/management/commands/sqlmigrate.py\nindex abc1234..def5678 100644\n--- a/django/core/management/commands/sqlmigrate.py\n+++ b/django/core/management/commands/sqlmigrate.py\n@@ -28,7 +28,8 @@ class Command(BaseCommand):\n             raise CommandError(\"App '{}' does not have migrations.\".format(app_label))\n \n         # Get the Migration\n-        self.output_transaction = migration.atomic\n+        connection = connections[db]\n+        self.output_transaction = migration.atomic and connection.features.can_rollback_ddl\n \n         # Get the SQL\n         sql_statements = []\ndiff --git a/tests/migrations/test_commands.py b/tests/migrations/test_commands.py\nindex xyz1234..uvw5678 100644\n--- a/tests/migrations/test_commands.py\n+++ b/tests/migrations/test_commands.py\n@@ -123,6 +123,25 @@ class SqlmigrateTests(MigrationTestBase):\n         out = StringIO()\n         call_command('sqlmigrate', 'migrations', '0001', stdout=out)\n         self.assertIn('-- Create model Salamander', out.getvalue())\n+    \n+    def test_sqlmigrate_non_atomic_no_ddl_rollback(self):\n+        \"\"\"\n+        sqlmigrate doesn't wrap output in BEGIN/COMMIT when can_rollback_ddl=False,\n+        even if the migration is atomic.\n+        \"\"\"\n+        # Create a test migration that is atomic\n+        before = self.make_project_state([])\n+        after = self.make_project_state([self.author_name])\n+        migration = type('Migration', (Migration,), {\n+            'dependencies': [],\n+            'operations': [migrations.CreateModel('Author', [('name', models.CharField(max_length=255))])],\n+            'atomic': True,\n+        })('0001', 'migrations')\n+        \n+        with mock.patch('django.db.connection.features.can_rollback_ddl', False):\n+            out = StringIO()\n+            call_command('sqlmigrate', 'migrations', '0001', stdout=out)\n+            self.assertNotIn('BEGIN', out.getvalue())\n \n     @override_settings(MIGRATION_MODULES={'migrations': 'migrations.test_migrations_squashed'})\n     def test_sqlmigrate_squashed(self):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13033",
    "model_patch": "diff --git a/django/db/models/sql/query.py b/django/db/models/sql/query.py\nindex abc1234..def5678 100644\n--- a/django/db/models/sql/query.py\n+++ b/django/db/models/sql/query.py\n@@ -1802,6 +1802,12 @@ class Query:\n             self.join(join_info)\n             alias = join_info.joins[-1]\n \n+        # Skip join if we're ordering by _id field directly on a self-referencing relation\n+        if (name.endswith('_id') and \n+            field.is_relation and \n+            field.remote_field.model == field.model):\n+            return self.join((field.model._meta.db_table, field.column, field), promote=True)\n+\n         return self.join(join_info)\n \n     def trim_joins(self, targets, joins, path):\n@@ -1904,6 +1910,9 @@ class Query:\n             if not field:\n                 raise FieldError('Invalid order_by arguments: %s' % arg)\n             if field.is_relation:\n+                # Clear any model-level ordering when explicit order_by is used\n+                if hasattr(field.model._meta, 'ordering'):\n+                    field.model._meta.ordering = []\n                 if not self._meta.ordering:\n                     self._meta.ordering = []\n                 self._meta.ordering.append(arg)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13265",
    "model_patch": "diff --git a/django/db/migrations/operations/models.py b/django/db/migrations/operations/models.py\nindex 9f8e4e2..c3b7b1e 100644\n--- a/django/db/migrations/operations/models.py\n+++ b/django/db/migrations/operations/models.py\n@@ -123,6 +123,8 @@ class AlterOrderWithRespectTo(ModelOptionOperation):\n         model._meta.order_with_respect_to = self.order_with_respect_to\n \n     def state_forwards(self, app_label, state):\n+        # Ensure the _order field is created before any indexes that use it.\n+        state.reload_model(app_label, self.name_lower)\n         state.models[app_label, self.name_lower].options['order_with_respect_to'] = self.order_with_respect_to\n \n     def describe(self):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15400",
    "model_patch": "diff --git a/django/utils/functional.py b/django/utils/functional.py\nindex e1f3c4a..b2d5f6g 100644\n--- a/django/utils/functional.py\n+++ b/django/utils/functional.py\n@@ -316,6 +316,11 @@ class SimpleLazyObject(LazyObject):\n             self._setup()\n         return other - self._wrapped\n \n+    def __radd__(self, other):\n+        if self._wrapped is empty:\n+            self._setup()\n+        return other + self._wrapped\n+\n     def __mul__(self, other):\n         if self._wrapped is empty:\n             self._setup()",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14999",
    "model_patch": "diff --git a/django/db/migrations/operations/models.py b/django/db/migrations/operations/models.py\nindex 4d8f9e1..3b2c6a7 100644\n--- a/django/db/migrations/operations/models.py\n+++ b/django/db/migrations/operations/models.py\n@@ -338,6 +338,10 @@ class RenameModel(ModelOperation):\n         return self.__class__.__name__ + \"(%s, %s)\" % (self.old_name, self.new_name)\n \n     def database_forwards(self, app_label, schema_editor, from_state, to_state):\n+        old_model = from_state.apps.get_model(app_label, self.old_name)\n+        if old_model._meta.db_table is not None:\n+            return\n+\n         new_model = to_state.apps.get_model(app_label, self.new_name)\n         if self.allow_migrate_model(schema_editor.connection.alias, new_model):\n             old_model = from_state.apps.get_model(app_label, self.old_name)\n@@ -345,6 +349,10 @@ class RenameModel(ModelOperation):\n             schema_editor.alter_db_table(new_model, old_model._meta.db_table, new_model._meta.db_table)\n \n     def database_backwards(self, app_label, schema_editor, from_state, to_state):\n+        new_model = from_state.apps.get_model(app_label, self.new_name)\n+        if new_model._meta.db_table is not None:\n+            return\n+\n         old_model = to_state.apps.get_model(app_label, self.old_name)\n         if self.allow_migrate_model(schema_editor.connection.alias, old_model):\n             new_model = from_state.apps.get_model(app_label, self.new_name)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14382",
    "model_patch": "diff --git a/django/core/management/templates.py b/django/core/management/templates.py\nindex abc1234..def5678 100644\n--- a/django/core/management/templates.py\n+++ b/django/core/management/templates.py\n@@ -74,7 +74,7 @@ class TemplateCommand(BaseCommand):\n             raise CommandError(\"'%s' already exists\" % target)\n \n         # Check that the app name is a valid identifier.\n-        self.validate_name(os.path.basename(target), 'directory')\n+        self.validate_name(os.path.basename(target.rstrip(os.sep)), 'directory')\n \n         if not options.get('skip_validation'):\n             self.validate_name(self.get_name(), 'app')",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11910",
    "model_patch": "diff --git a/app1/migrations/0002_auto.py b/app1/migrations/0002_auto.py\nindex abc1234..def5678 100644\n--- a/app1/migrations/0002_auto.py\n+++ b/app1/migrations/0002_auto.py\n@@ -10,5 +10,5 @@\n         migrations.AlterField(\n             model_name='modelb',\n             name='modela',\n-            field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='app1.ModelB', to_field='field_wrong'),\n+            field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='app1.ModelB', to_field='field_fixed'),\n         ),\n     ]",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12125",
    "model_patch": "diff --git a/django/db/migrations/serializer.py b/django/db/migrations/serializer.py\nindex abc1234..def5678 100644\n--- a/django/db/migrations/serializer.py\n+++ b/django/db/migrations/serializer.py\n@@ -123,6 +123,8 @@ class TypeSerializer(BaseSerializer):\n             return \"%s.%s\" % (module, value.__name__), imports\n         if hasattr(value, \"__module__\"):\n             module = value.__module__\n+            if hasattr(value, \"__qualname__\"):\n+                return \"%s.%s\" % (module, value.__qualname__), imports\n             return \"%s.%s\" % (module, value.__name__), imports\n         # Fallback to repr\n         return repr(value), imports",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14016",
    "model_patch": "diff --git a/django/db/models/query_utils.py b/django/db/models/query_utils.py\nindex 1b2c3d4..5e6f7g8 100644\n--- a/django/db/models/query_utils.py\n+++ b/django/db/models/query_utils.py\n@@ -1,5 +1,6 @@\n import copy\n import functools\n+from collections.abc import KeysView, ValuesView, ItemsView\n \n from django.utils import tree\n from django.utils.functional import cached_property\n@@ -23,6 +24,14 @@ class Q(tree.Node):\n         super().__init__(children=[], connector=connector, negated=negated)\n         self.add(filters, connector)\n \n+    def _make_pickleable(self, value):\n+        if isinstance(value, (KeysView, ValuesView, ItemsView)):\n+            return list(value)\n+        return value\n+\n+    def _prepare_child(self, child):\n+        child = (child[0], self._make_pickleable(child[1]))\n+        return child\n \n     def add(self, data, conn_type, squash=True):\n         \"\"\"\n@@ -45,6 +54,8 @@ class Q(tree.Node):\n             data = data.copy()\n             data.connector = conn_type\n             obj = data\n+        elif isinstance(data, (list, tuple)):\n+            obj = self._prepare_child(data)\n         else:\n             obj = data\n         super().add(obj, conn_type)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15252",
    "model_patch": "diff --git a/django/db/migrations/recorder.py b/django/db/migrations/recorder.py\nindex 1a2b3c4..5d6e7f8 100644\n--- a/django/db/migrations/recorder.py\n+++ b/django/db/migrations/recorder.py\n@@ -62,6 +62,9 @@ class MigrationRecorder:\n \n     def ensure_schema(self):\n         \"\"\"\n+        Check if the migration model should be created on this database\n+        connection according to the router's allow_migrate method.\n+        \"\"\"\n         with self.connection.schema_editor() as editor:\n             if self.Migration._meta.db_table not in self.connection.introspection.table_names(self.connection.cursor()):\n                 editor.create_model(self.Migration)\n@@ -69,6 +72,10 @@ class MigrationRecorder:\n \n     def applied_migrations(self):\n         \"\"\"\n+        Return the set of all migrations that have been applied to this database\n+        connection, checking the router's allow_migrate method.\n+        \"\"\"\n+        if not router.allow_migrate(self.connection.alias, self.Migration):\n+            return set()\n         self.ensure_schema()\n         return {\n             (migration.app, migration.name)\n@@ -78,6 +85,10 @@ class MigrationRecorder:\n \n     def record_applied(self, app, name):\n         \"\"\"\n+        Record that a migration was applied on this database connection,\n+        checking the router's allow_migrate method.\n+        \"\"\"\n+        if not router.allow_migrate(self.connection.alias, self.Migration):\n+            return\n         self.ensure_schema()\n         self.Migration.objects.using(self.connection.alias).create(app=app, name=name)\n \n@@ -86,6 +97,10 @@ class MigrationRecorder:\n \n     def record_unapplied(self, app, name):\n         \"\"\"\n+        Record that a migration was unapplied on this database connection,\n+        checking the router's allow_migrate method.\n+        \"\"\"\n+        if not router.allow_migrate(self.connection.alias, self.Migration):\n+            return\n         self.ensure_schema()\n         self.Migration.objects.using(self.connection.alias).filter(app=app, name=name).delete()",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14997",
    "model_patch": "diff --git a/myapp/models.py b/myapp/models.py\nindex abc1234..def5678 100644\n--- a/myapp/models.py\n+++ b/myapp/models.py\n@@ -6,8 +6,8 @@ class Tag(models.Model):\n     class Meta:\n         ordering = [\"name\", \"value\"]\n         constraints = [\n-            models.UniqueConstraint(\n-                \"name\",\n-                \"value\",\n+            models.UniqueConstraint(\n+                fields=[\"name\", \"value\"],\n                 name=\"unique_name_value\",\n             )\n         ]\ndiff --git a/myapp/migrations/0001_initial.py b/myapp/migrations/0001_initial.py\nindex abc1234..def5678 100644\n--- a/myapp/migrations/0001_initial.py\n+++ b/myapp/migrations/0001_initial.py\n@@ -19,7 +19,7 @@ class Migration(migrations.Migration):\n         ),\n         migrations.AddConstraint(\n             model_name='tag',\n-            constraint=models.UniqueConstraint(django.db.models.expressions.F('name'), django.db.models.expressions.F('value'), name='unique_name_value'),\n+            constraint=models.UniqueConstraint(fields=['name', 'value'], name='unique_name_value'),\n         ),\n     ]\n }",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15738",
    "model_patch": "diff --git a/app_name/models.py b/app_name/models.py\nindex abc1234..ghi9012 100644\n--- a/app_name/models.py\n+++ b/app_name/models.py\n@@ -6,6 +6,4 @@ class Authors(models.Model):\n     state = models.IntegerField()\n     start_date = models.DateField()\n     class Meta:\n-        unique_together = (('project_data_set', 'state', 'start_date'),)\n-\n-\n+        pass\n\n@@ -1,9 +1,7 @@\n class Authors(models.Model):\n-    project_data_set = models.ForeignKey(\n-        ProjectDataSet,\n-        on_delete=models.PROTECT\n-    )\n+    project_data_set = models.ManyToManyField(\n+        ProjectDataSet\n+    )\n     state = models.IntegerField()\n     start_date = models.DateField()\n     class Meta:",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13448",
    "model_patch": "diff --git a/django/test/runner.py b/django/test/runner.py\nindex 3f9b8a1..e1a2b3c 100644\n--- a/django/test/runner.py\n+++ b/django/test/runner.py\n@@ -613,6 +613,12 @@ class DiscoverRunner:\n         \"\"\"\n         return _setup_databases(\n             self.verbosity,\n             self.interactive,\n             time_keeper=self.time_keeper,\n             keepdb=self.keepdb,\n             debug_sql=self.debug_sql,\n             parallel=self.parallel,\n+            serialize=not any(\n+                connection.settings_dict['TEST'].get('MIGRATE', True) is False\n+                for connection in connections.all()\n+            ),\n             **kwargs\n         )\ndiff --git a/django/db/backends/base/creation.py b/django/db/backends/base/creation.py\nindex c4d5e6f..a7b8c9d 100644\n--- a/django/db/backends/base/creation.py\n+++ b/django/db/backends/base/creation.py\n@@ -74,8 +74,9 @@ class BaseDatabaseCreation:\n         \"\"\"\n         test_database_name = self._get_test_db_name()\n \n-        if self.connection.settings_dict['TEST'].get('MIGRATE', True):\n-            self.connection._test_serialized_contents = self.serialize_db_to_string()\n+        test_settings = self.connection.settings_dict['TEST']\n+        if test_settings.get('MIGRATE', True):\n+            self.connection._test_serialized_contents = self.serialize_db_to_string() if test_settings.get('SERIALIZE', True) else None\n \n         return test_database_name",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12708",
    "model_patch": "diff --git a/django/db/backends/base/schema.py b/django/db/backends/base/schema.py\nindex 2e8b7f9..3f4a1c2 100644\n--- a/django/db/backends/base/schema.py\n+++ b/django/db/backends/base/schema.py\n@@ -374,8 +374,14 @@ class BaseDatabaseSchemaEditor(object):\n             sql = self._delete_primary_key_sql(model, style)\n             self.execute(sql)\n \n-    def _delete_composed_index(self, model, fields, *args):\n-        \"\"\"\n+    def _delete_composed_index(self, model, fields, constraint_type='idx', *args):\n+        \"\"\"Delete a composite index or unique constraint.\n+\n+        The constraint_type can be 'idx' for index_together or 'uniq' for unique_together.\n+        This helps distinguish between the two when they share the same fields.\n+\n         Delete a composite index created by index_together or unique_together.\n         The fields should be a list of field names. The *args are the columns\n         that should be passed to _constraint_names() to compute the constraint\n@@ -383,7 +389,10 @@ class BaseDatabaseSchemaEditor(object):\n         \"\"\"\n         columns = [model._meta.get_field(field).column for field in fields]\n         for constraint_name in self._constraint_names(model, columns, *args):\n-            self.execute(self._delete_constraint_sql(self.sql_delete_index, model, constraint_name))\n+            if constraint_name.endswith('_' + constraint_type):\n+                self.execute(self._delete_constraint_sql(\n+                    self.sql_delete_index,\n+                    model,\n+                    constraint_name))\n \n     def _create_index_name(self, table_name, column_names, suffix=\"\"):\n         \"\"\"",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11564",
    "model_patch": "diff --git a/django/templatetags/static.py b/django/templatetags/static.py\nindex 5f6b6d2..4e7c8e9 100644\n--- a/django/templatetags/static.py\n+++ b/django/templatetags/static.py\n@@ -41,7 +41,10 @@ class StaticNode(Node):\n \n     def render(self, context):\n         url = self.url(context)\n-        if self.varname is None:\n+        script_name = context.get('request', {}).META.get('SCRIPT_NAME', '')\n+        if script_name:\n+            url = script_name.rstrip('/') + '/' + url.lstrip('/')\n+        \n         if self.varname is None:\n             return url\n         context[self.varname] = url\ndiff --git a/django/core/files/storage.py b/django/core/files/storage.py\nindex 3c4d8e1..7a8f4b3 100644\n--- a/django/core/files/storage.py\n+++ b/django/core/files/storage.py\n@@ -298,7 +298,10 @@ class FileSystemStorage(Storage):\n \n     def url(self, name):\n         # Return a URL that can be used to access the file.\n-        return self.base_url + filepath_to_uri(name)\n+        script_name = getattr(self.request, 'META', {}).get('SCRIPT_NAME', '')\n+        base_url = script_name.rstrip('/') + '/' + self.base_url.lstrip('/') if script_name else self.base_url\n+\n+        return base_url + filepath_to_uri(name)\n \n     def get_accessed_time(self, name):\n         # Return the last accessed time of the file.\n@@ -387,7 +387,10 @@ class StaticFilesStorage(FileSystemStorage):\n \n     def url(self, name):\n         # Return a URL that can be used to access the file.\n-        return super().url(name)\n+        script_name = getattr(self.request, 'META', {}).get('SCRIPT_NAME', '')\n+        base_url = script_name.rstrip('/') + '/' + self.base_url.lstrip('/') if script_name else self.base_url\n+\n+        return base_url + filepath_to_uri(name)\n \n     def path(self, name):\n         # Return the full path to the file.",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10924",
    "model_patch": "diff --git a/django/db/models/fields/__init__.py b/django/db/models/fields/__init__.py\nindex 60f1e65..b7a3d2c 100644\n--- a/django/db/models/fields/__init__.py\n+++ b/django/db/models/fields/__init__.py\n@@ -1449,6 +1449,8 @@ class FilePathField(CharField):\n             raise exceptions.ImproperlyConfigured(\"FilePathFields must have either 'allow_files' or 'allow_folders' set to True.\")\n         self.path = path\n         self.match = match\n+        if callable(self.path):\n+            self.path = self.path()\n         self.recursive = recursive\n         self.allow_files = allow_files\n         self.allow_folders = allow_folders\n@@ -1462,7 +1464,9 @@ class FilePathField(CharField):\n \n     def deconstruct(self):\n         name, path, args, kwargs = super().deconstruct()\n-        kwargs['path'] = self.path\n+        # Don't serialize callable paths\n+        if not callable(getattr(self, '_original_path', None)):\n+            kwargs['path'] = self.path\n         if self.match is not None:\n             kwargs['match'] = self.match\n         if self.recursive is not False:\n@@ -1474,6 +1478,10 @@ class FilePathField(CharField):\n         return name, path, args, kwargs\n \n     def formfield(self, **kwargs):\n+        # Handle callable path\n+        path = self.path\n+        if callable(path):\n+            path = path()\n         defaults = {\n             'path': path,\n             'match': self.match,",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13660",
    "model_patch": "diff --git a/django/core/management/commands/shell.py b/django/core/management/commands/shell.py\nindex 1234567..89abcde 100644\n--- a/django/core/management/commands/shell.py\n+++ b/django/core/management/commands/shell.py\n@@ -83,7 +83,7 @@ class Command(BaseCommand):\n         # Execute the command and exit.\n         if options['command']:\n-            exec(options['command'])\n+            exec(options['command'], {})\n             return\n         # Execute stdin if it has anything to read and exit.\n         # Not supported on Windows due to select.select() limitations.\n@@ -87,7 +87,7 @@ class Command(BaseCommand):\n         # Not supported on Windows due to select.select() limitations.\n         if sys.platform != 'win32' and not sys.stdin.isatty() and select.select([sys.stdin], [], [], 0)[0]:\n-            exec(sys.stdin.read())\n+            exec(sys.stdin.read(), {})\n             return",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12497",
    "model_patch": "diff --git a/django/db/models/fields/related.py b/django/db/models/fields/related.py\nindex 4b3e2d6..9c7f5a8 100644\n--- a/django/db/models/fields/related.py\n+++ b/django/db/models/fields/related.py\n@@ -1035,8 +1035,8 @@ class ManyToManyField(RelatedField):\n                     \"intermediate model %s has more than two \"\n                     \"foreign keys to %s, which is ambiguous and is \"\n                     \"not permitted. You must specify which two \"\n-                    \"foreign keys Django should use via the through_fields \"\n-                    \"keyword argument.\" % (self.remote_field.through, opts.object_name)\n+                    \"foreign keys Django should use via the through_fields keyword argument. \"\n+                    \"If you want to create a recursive relationship, use ManyToManyField('%s', through='%s').\" % (opts.object_name, self.remote_field.through)\n                 )\n \n     def _get_path_info(self, direct=False):",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11742",
    "model_patch": "diff --git a/django/db/models/fields/__init__.py b/django/db/models/fields/__init__.py\nindex 7e5f8e3..c1d2f4b 100644\n--- a/django/db/models/fields/__init__.py\n+++ b/django/db/models/fields/__init__.py\n@@ -1274,6 +1274,23 @@ class Field(RegisterLookupMixin):\n             params={'value': value},\n         )\n \n+    def _check_max_length_vs_choices(self):\n+        if self.max_length is not None and self.choices:\n+            max_choice_length = 0\n+            for choice, _ in self.flatchoices:\n+                if len(str(choice)) > max_choice_length:\n+                    max_choice_length = len(str(choice))\n+            if max_choice_length > self.max_length:\n+                return [\n+                    checks.Error(\n+                        \"'max_length' is too small to fit the longest value in 'choices'.\",\n+                        obj=self,\n+                        id='fields.E009',\n+                    )\n+                ]\n+        return []\n+\n     def _check_choices(self):\n         if not self.choices:\n             return []\n@@ -1282,6 +1299,7 @@ class Field(RegisterLookupMixin):\n \n     def check(self, **kwargs):\n         errors = []\n+        errors.extend(self._check_max_length_vs_choices())\n         errors.extend(self._check_choices())\n         errors.extend(self._check_field_name())\n         errors.extend(self._check_null_allowed_for_primary_keys())\ndiff --git a/tests/model_fields/test_fields.py b/tests/model_fields/test_fields.py\nindex f3b9d41..e5a6b21 100644\n--- a/tests/model_fields/test_fields.py\n+++ b/tests/model_fields/test_fields.py\n@@ -123,6 +123,25 @@ class FieldTests(SimpleTestCase):\n         with self.assertRaisesMessage(ValueError, msg):\n             field.clean('xyz', None)\n \n+    def test_max_length_vs_choices_validation(self):\n+        class TestModel(models.Model):\n+            field = models.CharField(\n+                max_length=5,\n+                choices=[\n+                    ('short', 'Short'),\n+                    ('toolong', 'Too long'),\n+                ],\n+            )\n+\n+        errors = TestModel.check()\n+        self.assertEqual(len(errors), 1)\n+        self.assertEqual(errors[0].id, 'fields.E009')\n+        self.assertIn(\n+            \"'max_length' is too small to fit the longest value in 'choices'.\",\n+            str(errors[0]),\n+        )\n+\n     def test_nullable_charfield_has_no_max_length_warning(self):\n         class TestModel(models.Model):\n             field = models.CharField(null=True)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14667",
    "model_patch": "diff --git a/django/db/models/query.py b/django/db/models/query.py\nindex 3b1c5f9..8d7e6a4 100644\n--- a/django/db/models/query.py\n+++ b/django/db/models/query.py\n@@ -1114,6 +1114,13 @@ class QuerySet:\n             raise TypeError(\"Cannot call defer() after .values() or .values_list()\")\n         clone = self._chain()\n \n+        if clone.query.deferred_loading[0]:\n+            # Remove any fields that are in both only() and defer()\n+            only_fields = set(clone.query.deferred_loading[0])\n+            defer_fields = set(fields)\n+            clone.query.deferred_loading = (\n+                list(only_fields - defer_fields),\n+                list(defer_fields | set(clone.query.deferred_loading[1])),\n+            )\n+\n         clone.query.add_deferred_loading(fields)\n         return clone\n \ndiff --git a/tests/defer/tests.py b/tests/defer/tests.py\nindex e69de29..a321b4f 100644\n--- a/tests/defer/tests.py\n+++ b/tests/defer/tests.py\n@@ -0,0 +1,28 @@\n+from django.db import connection\n+from django.test import TestCase\n+\n+from .models import Company\n+\n+\n+class DeferTests(TestCase):\n+    @classmethod\n+    def setUpTestData(cls):\n+        Company.objects.create(name='Test', trade_number='123', country='US')\n+\n+    def test_defer_after_only_same_field(self):\n+        with self.assertNumQueries(1):\n+            qs = Company.objects.only('name').defer('name')\n+            list(qs)\n+            self.assertEqual(\n+                str(connection.queries[-1]['sql']),\n+                'SELECT \"company\".\"id\" FROM \"company\"'\n+            )\n+\n+    def test_defer_multiple_after_only(self):\n+        with self.assertNumQueries(1):\n+            qs = Company.objects.only('name', 'country').defer('name')\n+            list(qs)\n+            self.assertEqual(\n+                str(connection.queries[-1]['sql']),\n+                'SELECT \"company\".\"id\", \"company\".\"country\" FROM \"company\"'\n+            )",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15814",
    "model_patch": "diff --git a/django/db/models/sql/query.py b/django/db/models/sql/query.py\n--- a/django/db/models/sql/query.py\n+++ b/django/db/models/sql/query.py\n@@ -742,7 +742,7 @@\n                 if not cur_model:\n                     continue\n                 # Even if the model was already seen, we may need to add more fields.\n-                opts = cur_model._meta\n+                opts = cur_model._meta.concrete_model._meta\n                 if opts in seen:\n                     seen[opts].update(fields)\n                     continue",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14672",
    "model_patch": "diff --git a/django/db/models/fields/reverse_related.py b/django/db/models/fields/reverse_related.py\nindex 2f5d6a7..3c9b8e1 100644\n--- a/django/db/models/fields/reverse_related.py\n+++ b/django/db/models/fields/reverse_related.py\n@@ -139,7 +139,7 @@ class ManyToManyRel(ForeignObjectRel):\n     @property\n     def identity(self):\n         return super().identity + (\n-            self.through_fields,\n+            make_hashable(self.through_fields),\n             self.through._meta.auto_created,\n         )",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15790",
    "model_patch": "diff --git a/django/core/checks/templates.py b/django/core/checks/templates.py\nindex 8b9f7c3..e5d4f1a 100644\n--- a/django/core/checks/templates.py\n+++ b/django/core/checks/templates.py\n@@ -54,7 +54,8 @@ def check_for_template_tags_with_the_same_name(app_configs, **kwargs):\n     for name, module_path in get_template_tag_modules():\n         if name in libraries:\n             if libraries[name] != module_path:\n-                errors.append(\n+                if not (libraries[name].startswith(module_path) or module_path.startswith(libraries[name])):\n+                    errors.append(\n                     Error(\n                         \"'%s' is used for multiple template tag modules: \"\n                         \"'%s', '%s'\" % (name, libraries[name], module_path),",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11630",
    "model_patch": "diff --git a/django/core/checks/model_checks.py b/django/core/checks/model_checks.py\nindex 5f6b7d8..9a0b1c2 100644\n--- a/django/core/checks/model_checks.py\n+++ b/django/core/checks/model_checks.py\n@@ -123,12 +123,12 @@ def check_model_name_db_table_clash(app_configs=None, **kwargs):\n     for db_table, names in used_db_tables.items():\n         if len(names) > 1:\n             errors.append(\n-                Error(\n+                Warning(\n                     \"db_table '%s' is used by multiple models: %s.\"\n                     % (db_table, ', '.join(sorted(names))),\n                     obj=db_table,\n-                    id='models.E028',\n-                ))\n+                    id='models.W028',\n+                )\n             )\n \n     return errors",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12470",
    "model_patch": "diff --git a/django/db/models/sql/compiler.py b/django/db/models/sql/compiler.py\nindex 3b8c1a2..7f9e5b6 100644\n--- a/django/db/models/sql/compiler.py\n+++ b/django/db/models/sql/compiler.py\n@@ -1200,7 +1200,7 @@ class SQLCompiler:\n             else:\n                 col, order = col_order\n             descending = order == 'DESC'\n-            if self.query.model._meta.order_with_respect_to and not self.query.standard_ordering:\n+            if self.query.model._meta.order_with_respect_to and not self.query.standard_ordering and not descending:\n                 # Special case: if we're ordering by the _order column of a\n                 # model with order_with_respect_to set, then NULLs are sorted\n                 # first. This is because NULL is used to mark the end of the",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13710",
    "model_patch": "diff --git a/django/contrib/admin/options.py b/django/contrib/admin/options.py\nindex abc1234..def5678 100644\n--- a/django/contrib/admin/options.py\n+++ b/django/contrib/admin/options.py\n@@ -1237,6 +1237,10 @@ class InlineModelAdmin(BaseModelAdmin):\n         if self.verbose_name is None:\n             self.verbose_name = self.model._meta.verbose_name\n \n+        # If verbose_name_plural isn't set, use the verbose_name as default\n+        if self.verbose_name_plural is None and self.verbose_name is not None:\n+            self.verbose_name_plural = self.verbose_name\n+\n     def get_queryset(self, request):\n         queryset = super().get_queryset(request)\n         if not self.has_view_or_change_permission(request):\ndiff --git a/tests/admin_inlines/tests.py b/tests/admin_inlines/tests.py\nindex xyz1234..uvw5678 100644\n--- a/tests/admin_inlines/tests.py\n+++ b/tests/admin_inlines/tests.py\n@@ -123,6 +123,20 @@ class TestInline(TestCase):\n         self.assertEqual(inline.verbose_name_plural, \"custom plural\")\n         self.assertEqual(inline.verbose_name, \"custom\")\n \n+    def test_inline_verbose_name_plural_defaults_to_verbose_name(self):\n+        \"\"\"\n+        When verbose_name is set but verbose_name_plural isn't, the plural should\n+        default to the same value as verbose_name.\n+        \"\"\"\n+        class CustomInline(TabularInline):\n+            model = Parent\n+            verbose_name = \"custom name\"\n+\n+        inline = CustomInline(Parent, admin.site)\n+        self.assertEqual(inline.verbose_name, \"custom name\")\n+        self.assertEqual(inline.verbose_name_plural, \"custom name\")\n+        # Should not affect the model's meta\n+        self.assertNotEqual(inline.verbose_name_plural, Parent._meta.verbose_name_plural)\n+\n     def test_inline_media(self):\n         class MediaInline(TabularInline):\n             model = Parent",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11422",
    "model_patch": "diff --git a/django/utils/autoreload.py b/django/utils/autoreload.py\nindex 7f8e123..a1b2c34 100644\n--- a/django/utils/autoreload.py\n+++ b/django/utils/autoreload.py\n@@ -299,6 +299,9 @@ def watched_files(self, include_globs=True):\n         # Start with all registered files.\n         yield from iter_all_python_module_files()\n         yield from self.extra_files\n+        # Also watch the main script file (manage.py)\n+        if sys.argv[0] not in self.extra_files:\n+            yield sys.argv[0]\n \n         # The above won't include non-python files that Django may\n         # be interested in (e.g. templates, static assets, etc.), so",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10914",
    "model_patch": "diff --git a/django/conf/global_settings.py b/django/conf/global_settings.py\nindex 3f4b2f1..b7e5d6c 100644\n--- a/django/conf/global_settings.py\n+++ b/django/conf/global_settings.py\n@@ -123,7 +123,7 @@ FILE_UPLOAD_HANDLERS = [\n     'django.core.files.uploadhandler.TemporaryFileUploadHandler',\n ]\n # The numeric mode to set newly-uploaded files to. The value should be a mode\n # you'd pass directly to os.chmod; see https://docs.python.org/3/library/os.html#files-and-directories.\n-FILE_UPLOAD_PERMISSIONS = None\n+FILE_UPLOAD_PERMISSIONS = 0o644\n \n # The numeric mode to assign to newly-created directories, when uploading files.\n # The value should be a mode as you'd pass to os.chmod;",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-12747",
    "model_patch": "diff --git a/django/db/models/query.py b/django/db/models/query.py\nindex 3c4f5a2..b7e6d8a 100644\n--- a/django/db/models/query.py\n+++ b/django/db/models/query.py\n@@ -810,6 +810,7 @@ class QuerySet:\n         collector = Collector(using=del_query.db)\n         collector.collect(del_query)\n         deleted, _rows_count = collector.delete()\n+        seen_models = set()\n \n-        for qs in collector.data.values():\n+        for model, instances in collector.data.items():\n+            if not instances and model._meta.label not in seen_models:\n+                seen_models.add(model._meta.label)\n+                update_counts(model, 0)\n             for obj in instances:\n                 model = obj.__class__\n                 if model._meta.auto_created and not force_policy:",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-13551",
    "model_patch": "diff --git a/django/contrib/auth/tokens.py b/django/contrib/auth/tokens.py\nindex 6f8c9e3..d1e2f9b 100644\n--- a/django/contrib/auth/tokens.py\n+++ b/django/contrib/auth/tokens.py\n@@ -30,7 +30,7 @@ class PasswordResetTokenGenerator:\n         # Truncate microseconds so that tokens are consistent even if the\n         # database doesn't support microseconds.\n         login_timestamp = '' if user.last_login is None else user.last_login.replace(microsecond=0, tzinfo=None)\n-        return str(user.pk) + user.password + str(login_timestamp) + str(timestamp)\n+        return str(user.pk) + user.password + str(login_timestamp) + str(timestamp) + (user.email or '')\n \n     def _make_token_with_timestamp(self, user, timestamp):\n         # timestamp is number of seconds since 2001-1-1. Converted to base 36,",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-15695",
    "model_patch": "diff --git a/django/db/migrations/operations/models.py b/django/db/migrations/operations/models.py\nindex 1234567..89abcde 100644\n--- a/django/db/migrations/operations/models.py\n+++ b/django/db/migrations/operations/models.py\n@@ -123,6 +123,8 @@ class RenameIndex(ModelOperation):\n         if self.old_name != self.new_name:\n             editor.rename_index(\n                 model_state._meta.apps.get_model(model_state.app_label, model_state.name),\n+                None if not self.old_name else self.old_name,  # Restore auto-generated name for unnamed indexes\n                 self.new_name,\n                 self.old_name,\n             )",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-14915",
    "model_patch": "diff --git a/django/forms/models.py b/django/forms/models.py\nindex 0a1b2c3..4d5e6f7 100644\n--- a/django/forms/models.py\n+++ b/django/forms/models.py\n@@ -1169,6 +1169,9 @@ class ModelChoiceIteratorValue:\n     def __str__(self):\n         return str(self.value)\n \n+    def __hash__(self):\n+        return hash(self.value)\n+\n \n class ModelChoiceIterator:\n     def __init__(self, field):",
    "model_name_or_path": "Chatgpt"
  }
]