[
  {
    "instance_id": "astropy__astropy-13579",
    "model_patch": "diff --git a/astropy/wcs/wcsapi/sliced_low_level_wcs.py\n+++ b/astropy/wcs/wcsapi/sliced_low_level_wcs.py\n@@ -248,22 +248,25 @@ class SlicedLowLevelWCS(BaseHighLevelWCS, BaseLowLevelWCS):\n         \"\"\"\n         Convert world coordinates to pixel coordinates.\n         \"\"\"\n-        # First, we need to expand the world coordinates to the full\n-        # dimensionality of the original WCS\n+        # Expand world coordinates to full WCS dimensionality\n         world_arrays_full = [None] * self._wcs.world_n_dim\n-        iworld = 0\n+        \n+        # Map input world coordinates to their correct positions in full WCS\n+        # The input world_arrays are ordered according to the sliced WCS,\n+        # but we need to place them at the correct positions in the full WCS\n         for iworld_full in range(self._wcs.world_n_dim):\n             if iworld_full in self._world_keep:\n-                world_arrays_full[iworld_full] = world_arrays[iworld]\n-                iworld += 1\n+                # Find which position in the sliced WCS this world axis corresponds to\n+                sliced_index = list(self._world_keep).index(iworld_full)\n+                world_arrays_full[iworld_full] = world_arrays[sliced_index]\n             else:\n                 world_arrays_full[iworld_full] = self._world_slice[iworld_full]\n \n         # Convert to pixel coordinates using the full WCS\n         pixel_arrays_full = self._wcs.world_to_pixel_values(*world_arrays_full)\n \n-        # Now extract the pixel coordinates for the dimensions that are kept\n+        # Extract pixel coordinates for the kept dimensions\n         pixel_arrays = []\n         for ipixel_full in self._pixel_keep:\n             pixel_arrays.append(pixel_arrays_full[ipixel_full])\n \n         return pixel_arrays\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14995",
    "model_patch": "diff --git a/astropy/nddata/mixins/arithmetics.py\n+++ b/astropy/nddata/mixins/arithmetics.py\n@@ -450,6 +450,18 @@ class NDArithmeticMixin:\n         if handle_mask is None:\n             return None\n \n+        # Handle None mask cases early to avoid type errors\n+        if mask1 is None and mask2 is None:\n+            return None\n+        elif mask1 is None:\n+            return deepcopy(mask2)\n+        elif mask2 is None:\n+            return deepcopy(mask1)\n+        \n+        # Ensure masks are boolean arrays for bitwise operations\n+        mask1 = np.asarray(mask1, dtype=bool)\n+        mask2 = np.asarray(mask2, dtype=bool)\n+\n         # If only one mask is present we need not bother about any type checks\n         if mask1 is None:\n             return deepcopy(mask2)\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11265",
    "model_patch": "diff --git a/django/db/models/sql/query.py\n+++ b/django/db/models/sql/query.py\n@@ -1601,6 +1601,10 @@ class Query:\n         query = Query(self.model)\n         query.add_filter(filter_expr)\n         query.clear_ordering(True)\n+        # Copy annotations and filtered relations to preserve context for exclude operations\n+        if hasattr(self, 'annotations') and self.annotations:\n+            query.annotations = self.annotations.copy()\n+        if hasattr(self, '_filtered_relations') and self._filtered_relations:\n+            query._filtered_relations = self._filtered_relations.copy()\n         # Try to have as simple as possible subquery -> trim leading joins from\n         # the subquery.\n         trimmed_prefix, contains_louter = query.trim_start(names_with_path)\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11206",
    "model_patch": "diff --git a/django/utils/numberformat.py\n+++ b/django/utils/numberformat.py\n@@ -30,6 +30,15 @@ def _format(number, decimal_sep, decimal_pos=None, grouping=0, thousand_sep='',\n     # sign\n     sign = ''\n     if isinstance(number, Decimal):\n+        # Handle extremely small decimals when decimal_pos is specified\n+        # to avoid exponential notation in the output\n+        if decimal_pos is not None and decimal_pos > 0:\n+            # Calculate the smallest representable value at this precision\n+            smallest_value = Decimal('1') / (Decimal('10') ** decimal_pos)\n+            if number != 0 and abs(number) < smallest_value:\n+                # Return zero formatted with the specified decimal places\n+                sign = '-' if number < 0 else ''\n+                return sign + '0' + decimal_sep + '0' * decimal_pos\n         # Format values with more than 200 digits (an arbitrary cutoff) using\n         # scientific notation to avoid high memory usage in {:f}\n         if abs(number) >= 10**200:\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-7671",
    "model_patch": "diff --git a/astropy/utils/introspection.py\n+++ b/astropy/utils/introspection.py\n@@ -1,6 +1,11 @@\n import inspect\n import sys\n import warnings\n+try:\n+    from packaging.version import parse as parse_version\n+except ImportError:\n+    # Fallback for older systems without packaging\n+    from distutils.version import LooseVersion\n \n from astropy.utils.exceptions import AstropyDeprecationWarning\n \n@@ -143,6 +148,18 @@ def minversion(module, version, inclusive=True, version_path=None):\n         have_version = resolve_name(module, version_path)\n \n     if inclusive:\n-        return LooseVersion(have_version) >= LooseVersion(version)\n+        return _compare_versions(have_version, version, '>=')\n     else:\n-        return LooseVersion(have_version) > LooseVersion(version)\n+        return _compare_versions(have_version, version, '>')\n+\n+\n+def _compare_versions(have_version, version, operator):\n+    \"\"\"Compare versions using packaging.version.parse with fallback.\"\"\"\n+    try:\n+        return parse_version(have_version) >= parse_version(version) if operator == '>=' else parse_version(have_version) > parse_version(version)\n+    except (NameError, TypeError, ValueError):\n+        # If packaging is not available or parsing fails, use string comparison\n+        # This is not ideal but better than crashing\n+        warnings.warn(f\"Version comparison using string comparison due to parsing issues\", UserWarning)\n+        return str(have_version) >= str(version) if operator == '>=' else str(have_version) > str(version)\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14309",
    "model_patch": "diff --git a/astropy/io/fits/connect.py\n+++ b/astropy/io/fits/connect.py\n@@ -69,4 +69,7 @@ def is_fits(origin, filepath, fileobj, *args, **kwargs):\n         (\".fits\", \".fits.gz\", \".fit\", \".fit.gz\", \".fts\", \".fts.gz\")\n     ):\n         return True\n-return isinstance(args[0], (HDUList, TableHDU, BinTableHDU, GroupsHDU))\n+# Check if we have args and if the first arg is a FITS object\n+if not args:\n+    return False\n+return isinstance(args[0], (HDUList, TableHDU, BinTableHDU, GroupsHDU))\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10554",
    "model_patch": "diff --git a/django/db/models/query.py\n+++ b/django/db/models/query.py\n@@ -430,6 +430,9 @@ class QuerySet:\n         clone = self._chain()\n         clone.query.combinator = 'UNION'\n         clone.query.combinator_all = all\n+        # Clear ordering from compound queries to prevent invalid ORDER BY references\n+        if clone.query.order_by:\n+            clone.query.clear_ordering(force_empty=True)\n         clone.query.combined_queries = (self.query,) + tuple(qs.query for qs in other_qs)\n         return clone\n \n@@ -460,6 +463,9 @@ class QuerySet:\n         clone = self._chain()\n         clone.query.combinator = 'INTERSECTION'\n         clone.query.combinator_all = all\n+        # Clear ordering from compound queries to prevent invalid ORDER BY references\n+        if clone.query.order_by:\n+            clone.query.clear_ordering(force_empty=True)\n         clone.query.combined_queries = (self.query,) + tuple(qs.query for qs in other_qs)\n         return clone\n \n@@ -490,6 +496,9 @@ class QuerySet:\n         clone = self._chain()\n         clone.query.combinator = 'DIFFERENCE'\n         clone.query.combinator_all = all\n+        # Clear ordering from compound queries to prevent invalid ORDER BY references\n+        if clone.query.order_by:\n+            clone.query.clear_ordering(force_empty=True)\n         clone.query.combined_queries = (self.query,) + tuple(qs.query for qs in other_qs)\n         return clone\n \n@@ -1000,6 +1009,12 @@ class QuerySet:\n         assert not self.query.is_sliced, \\\n             \"Cannot reorder a query once a slice has been taken.\"\n         obj = self._chain()\n+        # For compound queries, clear any existing ordering that might reference\n+        # invalid columns before applying new ordering\n+        if (obj.query.combinator and obj.query.order_by and \n+            field_names and field_names != (None,)):\n+            obj.query.clear_ordering(force_empty=True)\n+            \n         obj.query.clear_ordering(force_empty=False)\n         obj.query.add_ordering(*field_names)\n         return obj\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11141",
    "model_patch": "diff --git a/django/core/management/commands/migrate.py\n+++ b/django/core/management/commands/migrate.py\n@@ -90,10 +90,14 @@ class Command(BaseCommand):\n         # Import the 'management' module within each installed app, to register\n         # dispatcher events.\n         for app_config in apps.get_app_configs():\n             if module_has_submodule(app_config.module, 'migrations'):\n-                import_module('%s.migrations' % app_config.name)\n-                migrations_module = import_module('%s.migrations' % app_config.name)\n-                if not hasattr(migrations_module, '__file__'):\n-                    raise CommandError(\n-                        \"Django can't use migrations for app '%s' because it's not a package.\" % app_config.label\n-                    )\n+                try:\n+                    migrations_module = import_module('%s.migrations' % app_config.name)\n+                    # Check for __path__ which exists on both regular and namespace packages\n+                    if not hasattr(migrations_module, '__path__'):\n+                        raise CommandError(\n+                            \"Django can't use migrations for app '%s' because migrations module is not a package.\" % app_config.label\n+                        )\n+                except ImportError:\n+                    # Module exists but can't be imported - let migration loader handle this\n+                    pass\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11138",
    "model_patch": "diff --git a/django/db/backends/mysql/base.py\n+++ b/django/db/backends/mysql/base.py\n@@ -8,6 +8,7 @@ import warnings\n \n from django.core.exceptions import ImproperlyConfigured\n from django.db import IntegrityError\n+from django.conf import settings\n from django.db.backends.base.base import BaseDatabaseWrapper\n from django.utils.asyncio import async_unsafe\n from django.utils.encoding import force_str\n@@ -60,6 +61,12 @@ class DatabaseWrapper(BaseDatabaseWrapper):\n         super().__init__(settings_dict, alias)\n         self.features = DatabaseFeatures(self)\n         self.ops = DatabaseOperations(self)\n+        # Store the database timezone for use in operations\n+        # Fall back to global TIME_ZONE if not specified per-database\n+        self.timezone_name = (\n+            self.settings_dict.get('TIME_ZONE') or\n+            getattr(settings, 'TIME_ZONE', 'UTC')\n+        )\n         self.client = DatabaseClient(self)\n         self.creation = DatabaseCreation(self)\n         self.introspection = DatabaseIntrospection(self)\n--- a/django/db/backends/mysql/operations.py\n+++ b/django/db/backends/mysql/operations.py\n@@ -30,6 +30,19 @@ class DatabaseOperations(BaseDatabaseOperations):\n     def __init__(self, connection):\n         super().__init__(connection)\n \n+    def _get_timezone_conversion_sql(self, field_name, target_timezone):\n+        \"\"\"Helper method to generate timezone conversion SQL.\"\"\"\n+        if not settings.USE_TZ or not target_timezone:\n+            return field_name\n+            \n+        # Get the database timezone\n+        db_timezone = getattr(self.connection, 'timezone_name', 'UTC')\n+        \n+        # Skip conversion if source and target are the same\n+        if db_timezone == target_timezone:\n+            return field_name\n+        return \"CONVERT_TZ(%s, '%s', '%s')\" % (field_name, db_timezone, target_timezone)\n+\n     def autoinc_sql(self, table, column):\n         # To simulate the MySQL \"AUTO_INCREMENT\" attribute, we use the\n         # PostgreSQL \"SERIAL\" type.\n@@ -46,7 +59,7 @@ class DatabaseOperations(BaseDatabaseOperations):\n         if settings.USE_TZ:\n             # MySQL doesn't support tz-aware times\n             if timezone_name:\n-                return \"CONVERT_TZ(%s, 'UTC', '%s')\" % (field_name, timezone_name)\n+                return self._get_timezone_conversion_sql(field_name, timezone_name)\n         return field_name\n \n     def datetime_cast_date_sql(self, field_name, tzname):\n@@ -70,7 +83,7 @@ class DatabaseOperations(BaseDatabaseOperations):\n \n     def datetime_cast_sql(self, field_name, tzname):\n         if settings.USE_TZ:\n-            field_name = \"CONVERT_TZ(%s, 'UTC', '%s')\" % (field_name, tzname)\n+            field_name = self._get_timezone_conversion_sql(field_name, tzname)\n         return \"CAST(%s AS DATE)\" % field_name\n \n     def datetime_extract_sql(self, lookup_type, field_name, tzname):\n@@ -78,7 +91,7 @@ class DatabaseOperations(BaseDatabaseOperations):\n             # https://dev.mysql.com/doc/refman/5.6/en/date-and-time-functions.html\n             # MySQL's EXTRACT function doesn't respect the timezone.\n             if tzname:\n-                field_name = \"CONVERT_TZ(%s, 'UTC', '%s')\" % (field_name, tzname)\n+                field_name = self._get_timezone_conversion_sql(field_name, tzname)\n         return \"EXTRACT(%s FROM %s)\" % (lookup_type.upper(), field_name)\n \n     def datetime_trunc_sql(self, lookup_type, field_name, tzname):\n@@ -86,7 +99,7 @@ class DatabaseOperations(BaseDatabaseOperations):\n         if settings.USE_TZ:\n             # https://dev.mysql.com/doc/refman/5.6/en/date-and-time-functions.html\n             if tzname:\n-                field_name = \"CONVERT_TZ(%s, 'UTC', '%s')\" % (field_name, tzname)\n+                field_name = self._get_timezone_conversion_sql(field_name, tzname)\n         fields = {\n             'year': '%%Y-01-01',\n             'month': '%%Y-%%m-01',\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10097",
    "model_patch": "diff --git a/django/core/validators.py\n+++ b/django/core/validators.py\n@@ -84,6 +84,19 @@ class URLValidator(RegexValidator):\n     def __call__(self, value):\n         try:\n             super().__call__(value)\n+            \n+            # Additional validation for userinfo section per RFC 1738\n+            if '://' in value:\n+                scheme_and_rest = value.split('://', 1)\n+                if len(scheme_and_rest) == 2:\n+                    rest = scheme_and_rest[1]\n+                    if '@' in rest:\n+                        userinfo_and_host = rest.split('@', 1)\n+                        userinfo = userinfo_and_host[0]\n+                        \n+                        # Check for unencoded special characters in userinfo per RFC 1738\n+                        if '/' in userinfo or '@' in userinfo or userinfo.count(':') > 1:\n+                            raise ValidationError(self.message, code=self.code)\n         except ValidationError as e:\n             # Trivial case failed. Try for possible IDN domain\n             if value:\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-7606",
    "model_patch": "diff --git a/astropy/units/core.py\n+++ b/astropy/units/core.py\n@@ -1699,6 +1699,12 @@\n \n     def __eq__(self, other):\n+        # Handle None and other invalid types\n+        if other is None:\n+            return False\n+        try:\n+            other = Unit(other, parse_strict='silent')\n+        except (TypeError, ValueError):\n+            return False\n-        other = Unit(other, parse_strict='silent')\n         return isinstance(other, UnrecognizedUnit) and self.name == other.name\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14182",
    "model_patch": "diff --git a/astropy/io/ascii/rst.py\n+++ b/astropy/io/ascii/rst.py\n@@ -30,9 +30,10 @@ class RST(FixedWidth):\n     \"\"\"\n \n     def __init__(self, header_rows=None, **kwargs):\n-        super().__init__(**kwargs)\n+        super().__init__(header_rows=header_rows, **kwargs)\n         self.header = RSTHeader()\n         self.data = RSTData()\n+        self.header_rows = header_rows or ['name']\n \n \n class RSTHeader(FixedWidthHeader):\n@@ -85,15 +86,29 @@ class RSTHeader(FixedWidthHeader):\n         return lines\n \n     def _header_lines(self, lines):\n-        if self.parent_table.pformat_all:\n-            lines = super()._header_lines(lines)\n+        # Handle header_rows parameter\n+        if hasattr(self.parent_table, 'header_rows') and len(self.parent_table.header_rows) > 1:\n+            # Multiple header rows requested\n+            header_lines = []\n+            for header_row in self.parent_table.header_rows:\n+                line = []\n+                for col in self.cols:\n+                    if header_row == 'name':\n+                        line.append(col.info.name)\n+                    elif header_row == 'unit':\n+                        unit = getattr(col.info, 'unit', None)\n+                        line.append(str(unit) if unit is not None else '')\n+                    else:\n+                        line.append('')\n+                header_lines.append(line)\n+            return header_lines\n+        elif self.parent_table.pformat_all:\n+            return super()._header_lines(lines)\n         else:\n             # Use only col names, not the col<name> format that parent class uses\n-            lines = []\n+            header_lines = []\n             for i, col in enumerate(self.cols):\n-                lines.append(col.info.name)\n-\n-        return lines\n+                header_lines.append(col.info.name)\n+            return [header_lines]\n \n \n class RSTData(FixedWidthData):\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11179",
    "model_patch": "diff --git a/django/db/models/deletion.py\n+++ b/django/db/models/deletion.py\n@@ -281,6 +281,12 @@ class Collector:\n                 if count:\n                     deleted_counter[model._meta.label] += count\n \n+        # Set PK to None for all deleted instances\n+        for model, instances in self.data.items():\n+            pk_attname = model._meta.pk.attname\n+            for instance in instances:\n+                setattr(instance, pk_attname, None)\n+\n         # update collected instances\n         for instances_for_fieldvalues in self.field_updates.values():\n             for (field, value), instances in instances_for_fieldvalues.items():\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11276",
    "model_patch": "diff --git a/django/utils/html.py\n+++ b/django/utils/html.py\n@@ -12,19 +12,14 @@ from django.utils.safestring import SafeData, mark_safe\n \n \n def escape(text):\n     \"\"\"\n     Return the given text with ampersands, quotes and angle brackets encoded\n     for use in HTML.\n \n     Always escape input, even if it's already escaped and marked as such.\n     This may result in double-escaping. If this is a concern, use\n     conditional_escape() instead.\n+    \n+    Note: Single quotes are escaped as &#x27; (not &#39;) for compatibility\n+    with the Python standard library html.escape().\n     \"\"\"\n-    return (\n-        str(text)\n-        .replace(\"&\", \"&amp;\")\n-        .replace(\"<\", \"&lt;\")\n-        .replace(\">\", \"&gt;\")\n-        .replace('\"', \"&quot;\")\n-        .replace(\"'\", \"&#x27;\")\n-    )\n+    return html.escape(str(text), quote=True)\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-13453",
    "model_patch": "diff --git a/astropy/io/ascii/html.py\n+++ b/astropy/io/ascii/html.py\n@@ -97,8 +97,15 @@ class HTML(core.BaseReader):\n         # Add data rows\n         for row in self.table:\n             lines.append('<tr>')\n             for col in self.cols:\n-                lines.append('<td>{}</td>'.format(row[col.info.name]))\n+                value = row[col.info.name]\n+                # Apply format if specified\n+                if (hasattr(self, 'formats') and self.formats and \n+                    col.info.name in self.formats):\n+                    format_func = self.formats[col.info.name]\n+                    value = format_func(value)\n+                lines.append('<td>{}</td>'.format(value))\n             lines.append('</tr>')\n+        \n         lines.append('</table>')\n         lines.append('</body>')\n         lines.append('</html>')\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14598",
    "model_patch": "diff --git a/astropy/io/fits/card.py\n+++ b/astropy/io/fits/card.py\n@@ -485,7 +485,12 @@ class Card:\n                 # Handle quoted string values\n                 if value.startswith(\"'\") and value.endswith(\"'\"):\n                     # Remove outer quotes and unescape inner quotes\n-                    value = value[1:-1].replace(\"''\", \"'\")\n+                    inner_value = value[1:-1]\n+                    # Handle the special case where the entire inner value is just ''\n+                    if inner_value == \"''\":\n+                        value = \"'\"  # This represents a literal single quote\n+                    else:\n+                        value = inner_value.replace(\"''\", \"'\")\n                 else:\n                     try:\n                         # Try to parse as number\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11433",
    "model_patch": "diff --git a/django/forms/models.py\n+++ b/django/forms/models.py\n@@ -451,6 +451,12 @@ class BaseModelForm(BaseForm):\n         if self.instance.pk is None:\n             fail_message = 'created'\n         else:\n             fail_message = 'changed'\n+        \n+        # Apply all cleaned_data values to instance, including fields not in form\n+        for field_name, value in self.cleaned_data.items():\n+            if hasattr(self.instance, field_name):\n+                setattr(self.instance, field_name, value)\n+        \n         return save_instance(self, self.instance, self._meta.fields,\n                              fail_message, commit, self._meta.exclude,\n                              construct=False)\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10914",
    "model_patch": "diff --git a/django/conf/global_settings.py\n+++ b/django/conf/global_settings.py\n@@ -500,7 +500,7 @@ FILE_UPLOAD_TEMP_DIR = None\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/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;\n--- a/django/core/files/storage.py\n+++ b/django/core/files/storage.py\n@@ -250,6 +250,8 @@ class FileSystemStorage(Storage):\n             # This file has a file path that we can move.\n             if hasattr(content, 'temporary_file_path'):\n                 file_move_safe(content.temporary_file_path(), full_path)\n+                # Ensure consistent permissions after moving from temp file\n+                os.chmod(full_path, self.file_permissions_mode or 0o644)\n             else:\n                 # This is a normal uploadedfile that we can stream.\n                 # This fun binary flag incantation makes os.open throw an\n@@ -265,7 +267,8 @@ class FileSystemStorage(Storage):\n                     fd.write(chunk)\n \n         if self.file_permissions_mode is not None:\n             os.chmod(full_path, self.file_permissions_mode)\n+        else:\n+            os.chmod(full_path, 0o644)\n \n         # Store the final file size in the payload.\n         content.size = len(content)\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11133",
    "model_patch": "diff --git a/django/http/response.py\n+++ b/django/http/response.py\n@@ -342,6 +342,8 @@ class HttpResponse:\n     @content.setter\n     def content(self, value):\n         # Consume iterators and convert bytes to strings\n+        if isinstance(value, memoryview):\n+            value = value.tobytes()\n         if hasattr(value, '__iter__') and not isinstance(value, (bytes, str)):\n             content = b''.join(self.make_bytes(chunk) for chunk in value)\n             if hasattr(value, 'close'):\n@@ -356,6 +358,8 @@ class HttpResponse:\n \n     def make_bytes(self, value):\n         \"\"\"Turn a value into a bytestring encoded in the output charset.\"\"\"\n+        if isinstance(value, memoryview):\n+            return value.tobytes()\n         # Handle string types -- we can't rely on force_bytes here because:\n         # - Python attempts str conversion first\n         # - when self._charset != 'utf-8' it re-encodes the content\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14539",
    "model_patch": "diff --git a/astropy/io/fits/diff.py\n+++ b/astropy/io/fits/diff.py\n@@ -800,6 +800,20 @@ class FITSDiff:\n         if isinstance(a, np.ndarray) and isinstance(b, np.ndarray):\n             return self._array_compare(a, b)\n \n+        # Handle VLA (Variable Length Array) elements\n+        # VLA elements might be numpy arrays or array-like objects that need special handling\n+        if hasattr(a, '__len__') and hasattr(b, '__len__') and not isinstance(a, (str, bytes)) and not isinstance(b, (str, bytes)):\n+            try:\n+                # Convert to numpy arrays for consistent comparison\n+                a_arr = np.asarray(a)\n+                b_arr = np.asarray(b)\n+                # Use array comparison if both are now arrays\n+                if a_arr.shape == b_arr.shape:\n+                    return self._array_compare(a_arr, b_arr)\n+                else:\n+                    return False\n+            except (ValueError, TypeError):\n+                # Fall back to element-wise comparison if array conversion fails\n+                pass\n+\n         if isinstance(a, np.floating) and isinstance(b, np.floating):\n             if np.isnan(a) and np.isnan(b):\n                 return True\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-13398",
    "model_patch": "diff --git a/astropy/coordinates/itrs.py\n+++ b/astropy/coordinates/itrs.py\n@@ -1,6 +1,12 @@\n import numpy as np\n from astropy import units as u\n from astropy.coordinates.baseframe import BaseCoordinateFrame, base_doc\n+from astropy.coordinates.matrix_utilities import rotation_matrix, matrix_transpose\n+from astropy.coordinates.baseframe import frame_transform_graph\n+from astropy.coordinates.transformations import FunctionTransformWithFiniteDifference\n from astropy.coordinates.attributes import TimeAttribute, EarthLocationAttribute\n+from .altaz import AltAz\n+from .hadec import HADec\n+from .utils import PIOVER2\n \n __all__ = ['ITRS']\n \n@@ -95,3 +101,68 @@ class ITRS(BaseCoordinateFrame):\n     default_representation = CartesianRepresentation\n     default_differential = CartesianDifferential\n \n+\n+def itrs_to_observed_mat(observed_frame):\n+    \"\"\"Construct rotation matrix from ITRS to observed frame (AltAz or HADec).\n+    \n+    Parameters\n+    ----------\n+    observed_frame : AltAz or HADec\n+        The target observed frame\n+        \n+    Returns\n+    -------\n+    mat : ndarray\n+        3x3 rotation matrix\n+    \"\"\"\n+    if observed_frame.location is None:\n+        raise ValueError(\"observed_frame must have a location attribute\")\n+        \n+    lon, lat, height = observed_frame.location.to_geodetic('WGS84')\n+    elong = lon.to_value(u.radian)\n+\n+    if isinstance(observed_frame, AltAz):\n+        # form ITRS to AltAz matrix\n+        elat = lat.to_value(u.radian)\n+        # AltAz frame is left handed\n+        minus_x = np.eye(3)\n+        minus_x[0][0] = -1.0\n+        mat = (minus_x\n+               @ rotation_matrix(PIOVER2 - elat, 'y', unit=u.radian)\n+               @ rotation_matrix(elong, 'z', unit=u.radian))\n+\n+    else:\n+        # form ITRS to HADec matrix\n+        # HADec frame is left handed\n+        minus_y = np.eye(3)\n+        minus_y[1][1] = -1.0\n+        mat = (minus_y\n+               @ rotation_matrix(elong, 'z', unit=u.radian))\n+    return mat\n+\n+\n+@frame_transform_graph.transform(FunctionTransformWithFiniteDifference, ITRS, AltAz)\n+@frame_transform_graph.transform(FunctionTransformWithFiniteDifference, ITRS, HADec)\n+def itrs_to_observed(itrs_coo, observed_frame):\n+    \"\"\"Direct transformation from ITRS to observed frame staying within ITRS.\n+    \n+    This avoids the problematic ITRS->ITRS transform that references coordinates\n+    to the SSB instead of the rotating ITRF. ITRS coordinates are treated as\n+    time invariant.\n+    \"\"\"\n+    # form the Topocentric ITRS position\n+    topocentric_itrs_repr = (itrs_coo.cartesian\n+                             - observed_frame.location.get_itrs().cartesian)\n+    rep = topocentric_itrs_repr.transform(itrs_to_observed_mat(observed_frame))\n+    return observed_frame.realize_frame(rep)\n+\n+\n+@frame_transform_graph.transform(FunctionTransformWithFiniteDifference, AltAz, ITRS)\n+@frame_transform_graph.transform(FunctionTransformWithFiniteDifference, HADec, ITRS)\n+def observed_to_itrs(observed_coo, itrs_frame):\n+    \"\"\"Direct transformation from observed frame to ITRS staying within ITRS.\"\"\"\n+    # form the Topocentric ITRS position\n+    topocentric_itrs_repr = observed_coo.cartesian.transform(matrix_transpose(\n+                            itrs_to_observed_mat(observed_coo)))\n+    # form the Geocentric ITRS position\n+    rep = topocentric_itrs_repr + observed_coo.location.get_itrs().cartesian\n+    return itrs_frame.realize_frame(rep)\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11292",
    "model_patch": "diff --git a/django/core/management/base.py\n+++ b/django/core/management/base.py\n@@ -390,6 +390,10 @@ class BaseCommand:\n             '--force-color', action='store_true',\n             help='Force colorization of the command output.',\n         )\n+        parser.add_argument(\n+            '--skip-checks', action='store_true',\n+            help='Skip system checks.'\n+        )\n \n     def add_arguments(self, parser):\n         \"\"\"\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11087",
    "model_patch": "diff --git a/django/db/models/deletion.py\n+++ b/django/db/models/deletion.py\n@@ -138,7 +138,18 @@ class Collector:\n     def related_objects(self, related, objs):\n         \"\"\"\n         Return all objects related to ``objs`` via the relation ``related``.\n         \"\"\"\n         field = related.remote_field\n-        return field.model._base_manager.using(self.using).filter(\n+        queryset = field.model._base_manager.using(self.using).filter(\n             **{\"%s__in\" % field.name: objs}\n         )\n+        \n+        # Optimize for deletion: only fetch essential fields to avoid\n+        # UnicodeDecodeError on problematic text fields\n+        model = field.model\n+        pk_name = model._meta.pk.name\n+        essential_fields = [pk_name]\n+        \n+        # Include foreign key fields needed for cascade operations\n+        for f in model._meta.get_fields():\n+            if (f.many_to_one or f.one_to_one) and hasattr(f, 'name') and f.name != pk_name:\n+                essential_fields.append(f.name)\n+        \n+        return queryset.only(*essential_fields)\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11066",
    "model_patch": "diff --git a/django/contrib/contenttypes/management/__init__.py\n+++ b/django/contrib/contenttypes/management/__init__.py\n@@ -27,4 +27,4 @@ class RenameContentType:\n             content_type.model = new_model\n             with transaction.atomic(using=db):\n-                content_type.save(update_fields={'model'})\n+                content_type.save(using=db, update_fields={'model'})\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11299",
    "model_patch": "diff --git a/django/db/models/constraints.py\n+++ b/django/db/models/constraints.py\n@@ -150,6 +150,22 @@ class CheckConstraint(BaseConstraint):\n         return schema_editor._check_sql(self.name, check)\n \n     def _get_check_sql(self, model, schema_editor):\n+        def replace_col_with_simplecol(expr):\n+            \"\"\"\n+            Recursively replace Col instances with SimpleCol instances to avoid\n+            qualified column names in CHECK constraints.\n+            \"\"\"\n+            from django.db.models.expressions import SimpleCol\n+            \n+            # Process children first if they exist\n+            if hasattr(expr, 'children') and expr.children:\n+                for i, child in enumerate(expr.children):\n+                    expr.children[i] = replace_col_with_simplecol(child)\n+            \n+            # Replace Col with SimpleCol\n+            if expr.__class__.__name__ == 'Col':\n+                return SimpleCol(expr.target, expr.output_field)\n+            \n+            return expr\n+        \n         query = Query(model=model, alias_cols=False)\n         where = query.build_where(self.check)\n         compiler = query.get_compiler(connection=schema_editor.connection)\n@@ -157,6 +173,7 @@ class CheckConstraint(BaseConstraint):\n         if where.children:\n             # Extract the expression from the where clause\n             expr = where.children[0] if len(where.children) == 1 else where\n+            expr = replace_col_with_simplecol(expr)\n             sql, params = compiler.compile(expr)\n             return sql % params\n         return ''\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14508",
    "model_patch": "diff --git a/astropy/io/fits/card.py\n+++ b/astropy/io/fits/card.py\n@@ -1299,8 +1299,12 @@ class Card(_Verify):\n         \"\"\"\n         # The FITS standard does not specify the precision of floating point\n         # values, so we use the default Python precision.\n-        value_str = f\"{value:.16G}\"\n-        return value_str\n+        # First try the default string representation\n+        value_str = str(value)\n+        # If it's too long (>20 chars), use formatted precision\n+        if len(value_str) > 20:\n+            value_str = f\"{value:.16G}\"\n+        return value_str\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-13236",
    "model_patch": "diff --git a/astropy/table/table.py\n+++ b/astropy/table/table.py\n@@ -1,6 +1,7 @@\n import collections\n import copy\n import itertools\n+import warnings\n from collections import OrderedDict\n from collections.abc import Mapping\n from copy import deepcopy\n@@ -1440,6 +1441,15 @@ class Table:\n         # Structured ndarray gets viewed as a mixin unless already a valid\n         # mixin class\n         if (not isinstance(data, Column) and not data_is_mixin\n                 and isinstance(data, np.ndarray) and len(data.dtype) > 1):\n+            # TODO: Remove this entire block in astropy 5.2\n+            warnings.warn(\n+                \"Structured numpy arrays are being automatically converted to \"\n+                \"NdarrayMixin. This behavior will change in astropy 5.2 where \"\n+                \"structured arrays will be added as Column instances. To prepare \"\n+                \"for this change and silence this warning, explicitly wrap your \"\n+                \"structured array with Column().\",\n+                FutureWarning,\n+                stacklevel=3)\n             data = data.view(NdarrayMixin)\n             data_is_mixin = True\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11119",
    "model_patch": "diff --git a/django/template/engine.py\n+++ b/django/template/engine.py\n@@ -185,7 +185,10 @@ class Engine:\n         if context is None:\n             context = {}\n         if isinstance(context, dict):\n-            context = Context(context)\n+            # Pass the engine's autoescape setting to the context\n+            context = Context(context, autoescape=self.autoescape)\n+        elif hasattr(context, 'autoescape'):\n+            # Ensure existing context respects engine's autoescape setting\n+            context.autoescape = self.autoescape\n         try:\n             return template.render(context, request)\n         except TemplateDoesNotExist:\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10880",
    "model_patch": "diff --git a/django/db/models/aggregates.py\n+++ b/django/db/models/aggregates.py\n@@ -82,7 +82,7 @@ class Count(Aggregate):\n         if self.distinct:\n             if len(self.source_expressions) > 1:\n                 raise TypeError('COUNT DISTINCT with multiple fields is not supported.')\n-            sql = 'DISTINCT' + sql\n+            sql = 'DISTINCT ' + sql\n         return self.filter(\n             extra_context={'distinct': self.distinct},\n             template=template % sql,\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11451",
    "model_patch": "diff --git a/django/contrib/auth/backends.py\n+++ b/django/contrib/auth/backends.py\n@@ -18,6 +18,8 @@ class ModelBackend(BaseBackend):\n     def authenticate(self, request, username=None, password=None, **kwargs):\n         if username is None:\n             username = kwargs.get(UserModel.USERNAME_FIELD)\n+        if username is None:\n+            return None\n         try:\n             user = UserModel._default_manager.get_by_natural_key(username)\n         except UserModel.DoesNotExist:\n--- a/tests/auth_tests/test_backends.py\n+++ b/tests/auth_tests/test_backends.py\n@@ -1,6 +1,7 @@\n import inspect\n \n from django.contrib.auth import authenticate, get_user\n+from django.test import TestCase, override_settings\n from django.contrib.auth.backends import ModelBackend\n from django.contrib.auth.models import AnonymousUser, Permission, User\n from django.contrib.contenttypes.models import ContentType\n@@ -45,6 +46,15 @@ class ModelBackendTest(TestCase):\n         user = authenticate(username='test', password='test')\n         self.assertIsNone(user)\n \n+    def test_authenticate_with_none_username_does_not_query_db(self):\n+        \"\"\"authenticate() should not make database queries when username is None.\"\"\"\n+        with self.assertNumQueries(0):\n+            user = authenticate(username=None, password='test')\n+            self.assertIsNone(user)\n+        \n+        with self.assertNumQueries(0):\n+            user = authenticate(password='test')  # username defaults to None\n+            self.assertIsNone(user)\n+\n     def test_authenticate_with_invalid_username(self):\n         ret = authenticate(username='unknown', password='test')\n         self.assertIsNone(ret)\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11099",
    "model_patch": "diff --git a/django/contrib/auth/validators.py\n+++ b/django/contrib/auth/validators.py\n@@ -16,7 +16,7 @@ class ASCIIUsernameValidator(validators.RegexValidator):\n     def __init__(self, **kwargs):\n         super().__init__(\n-            regex=r'^[\\w.@+-]+$',\n+            regex=r'\\A[\\w.@+-]+\\Z',\n             message=_(\n                 'Enter a valid username. This value may contain only English letters, '\n                 'numbers, and @/./+/-/_ characters.'\n@@ -27,7 +27,7 @@ class UnicodeUsernameValidator(validators.RegexValidator):\n     def __init__(self, **kwargs):\n         super().__init__(\n-            regex=r'^[\\w.@+-]+$',\n+            regex=r'\\A[\\w.@+-]+\\Z',\n             message=_(\n                 'Enter a valid username. This value may contain only letters, '\n                 'numbers, and @/./+/-/_ characters.'\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10999",
    "model_patch": "diff --git a/django/utils/dateparse.py\n+++ b/django/utils/dateparse.py\n@@ -15,7 +15,7 @@ standard_duration_re = re.compile(\n     r'^'\n     r'(?:(?P<days>-?\\d+) (days?, )?)?'\n-    r'((?:(?P<hours>-?\\d+):)(?=\\d+:\\d+))?'\n+    r'((?:(?P<hours>-?\\d+):)(?=-?\\d+:-?\\d+))?'\n     r'(?:(?P<minutes>-?\\d+):)?'\n     r'(?P<seconds>-?\\d+)'\n     r'(?:\\.(?P<microseconds>\\d{1,6})\\d{0,6})?'\n--- a/tests/utils_tests/test_dateparse.py\n+++ b/tests/utils_tests/test_dateparse.py\n@@ -45,6 +45,18 @@ class DateParseTests(unittest.TestCase):\n         self.assertEqual(parse_duration('1 02:03:04.000005'), expected)\n         self.assertEqual(parse_duration('1 day, 02:03:04.000005'), expected)\n \n+        # Test negative durations\n+        expected = datetime.timedelta(days=-1, hours=-2, minutes=-3, seconds=-4, microseconds=-5)\n+        self.assertEqual(parse_duration('-1 -02:-03:-04.000005'), expected)\n+        \n+        expected = datetime.timedelta(hours=-2, minutes=-3, seconds=-4)\n+        self.assertEqual(parse_duration('-02:-03:-04'), expected)\n+        \n+        expected = datetime.timedelta(minutes=-30, seconds=-45)\n+        self.assertEqual(parse_duration('-30:-45'), expected)\n+        \n+        expected = datetime.timedelta(seconds=-123)\n+        self.assertEqual(parse_duration('-123'), expected)\n+\n     def test_parse_duration_invalid(self):\n         with self.assertRaises(ValueError):\n             parse_duration('invalid')\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11333",
    "model_patch": "diff --git a/django/urls/resolvers.py\n+++ b/django/urls/resolvers.py\n@@ -581,7 +581,11 @@ def _get_resolver(urlconf=None):\n \n \n def get_resolver(urlconf=None):\n-    return _get_resolver(urlconf)\n+    if urlconf is None:\n+        urlconf = get_urlconf()\n+        if urlconf is None:\n+            from django.conf import settings\n+            urlconf = settings.ROOT_URLCONF\n+    return _get_resolver(urlconf)\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-13033",
    "model_patch": "diff --git a/astropy/timeseries/sampled.py\n+++ b/astropy/timeseries/sampled.py\n@@ -97,9 +97,12 @@ class TimeSeries(BaseTimeSeries):\n         Check that the required columns are present and in the right order\n         \"\"\"\n         if self._required_columns is not None:\n-            if not self._required_columns <= set(self.colnames):\n-                raise ValueError(\"TimeSeries object is invalid - expected \"\n-                                 \"'time' as the first columns but found '{}'\".format(self.colnames[0]))\n+            missing_columns = [col for col in self._required_columns if col not in self.colnames]\n+            if missing_columns:\n+                missing_str = \"', '\".join(missing_columns)\n+                present_str = \"', '\".join(self.colnames)\n+                raise ValueError(f\"TimeSeries object is missing required column(s): '{missing_str}'. \"\n+                               f\"Present columns are: '{present_str}'\")\n \n     def __init__(self, data=None, *, time=None, time_start=None, time_delta=None, n_samples=None, **kwargs):\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14369",
    "model_patch": "diff --git a/astropy/io/ascii/cds.py\n+++ b/astropy/io/ascii/cds.py\n@@ -570,6 +570,14 @@ def split_cds_units(unit):\n     # Replace ^ with **\n     unit = unit.replace('^', '**')\n \n+    # Fix division precedence for CDS composite units\n+    # When there are multiple '/' operators, group the denominator terms\n+    slash_count = unit.count('/')\n+    if slash_count > 1:\n+        first_slash = unit.find('/')\n+        numerator = unit[:first_slash]\n+        denominator = unit[first_slash+1:].replace('/', '*')\n+        unit = f'{numerator}/({denominator})'\n+\n     try:\n         return u.Unit(unit)\n     except (ValueError, TypeError):\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-12907",
    "model_patch": "diff --git a/astropy/modeling/separable.py\n+++ b/astropy/modeling/separable.py\n@@ -82,7 +82,7 @@ def _traverse_model_graph(model, inputs, outputs):\n     \"\"\"\n     Traverse the model graph and collect input/output information.\n     \n     This function recursively traverses a model and its submodels.\n     \"\"\"\n     from astropy.modeling.core import Model\n     from astropy.modeling.mappings import Mapping\n+    from astropy.modeling.core import CompoundModel\n \n     if isinstance(model, Model):\n         if isinstance(model, Mapping):\n@@ -95,9 +95,15 @@ def _traverse_model_graph(model, inputs, outputs):\n             outputs.extend(range(n_outputs))\n         else:\n             # Handle compound models\n+            input_start = len(inputs)\n+            output_start = len(outputs)\n+            \n             for submodel_name in model.submodel_names:\n                 submodel = getattr(model, submodel_name)\n-                _traverse_model_graph(submodel, inputs, outputs)\n+                if isinstance(submodel, CompoundModel):\n+                    _traverse_model_graph(submodel, inputs, outputs)\n+                else:\n+                    inputs.extend(range(input_start + len(inputs) - input_start, input_start + len(inputs) - input_start + submodel.n_inputs))\n+                    outputs.extend(range(output_start + len(outputs) - output_start, output_start + len(outputs) - output_start + submodel.n_outputs))\n \n \n def _flatten_inputs_outputs(model, inputs, outputs):\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14365",
    "model_patch": "diff --git a/astropy/io/ascii/qdp.py\n+++ b/astropy/io/ascii/qdp.py\n@@ -140,6 +140,10 @@ def _line_type(line, delimiter=None):\n     return _QDPLineType.DATA, None\n \n \n+def _command_matches(line, command):\n+    \"\"\"Check if line starts with command (case-insensitive).\"\"\"\n+    return line.upper().startswith(command.upper())\n+\n def _get_type_from_list_of_lines(lines, delimiter=None):\n     \"\"\"\n     Scan the lines to determine table type.\n@@ -179,17 +183,17 @@ def _get_type_from_list_of_lines(lines, delimiter=None):\n         if not line:\n             continue\n \n-        if line.startswith(\"READ SERR\"):\n+        if _command_matches(line, \"READ SERR\"):\n             serr_line = line\n-        elif line.startswith(\"READ TERR\"):\n+        elif _command_matches(line, \"READ TERR\"):\n             terr_line = line\n-        elif line.startswith(\"READ\"):\n+        elif _command_matches(line, \"READ\"):\n             # This is a read command but not SERR or TERR\n             pass\n         elif line.startswith(\"!\"):\n             # Comment line\n             continue\n-        elif line.startswith((\"SKIP\", \"NO\", \"PLOT\", \"TIME\", \"LST\", \"LAB\")):\n+        elif _command_matches(line, \"SKIP\") or _command_matches(line, \"NO\") or _command_matches(line, \"PLOT\") or _command_matches(line, \"TIME\") or _command_matches(line, \"LST\") or _command_matches(line, \"LAB\"):\n             # Other QDP commands\n             continue\n         else:\n@@ -248,7 +252,7 @@ def _get_lines_from_file(qdp_file):\n         if not line:\n             continue\n \n-        if line.startswith(\"READ\"):\n+        if _command_matches(line, \"READ\"):\n             command_lines.append(line)\n         elif line.startswith(\"!\"):\n             # Comment line\n@@ -318,7 +322,7 @@ def _get_tables_from_qdp_file(qdp_file, input_colnames=None, delimiter=None):\n         if not line:\n             continue\n \n-        if line.startswith(\"READ\"):\n+        if _command_matches(line, \"READ\"):\n             # Process READ command\n             continue\n         elif line.startswith(\"!\"):\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11400",
    "model_patch": "diff --git a/django/contrib/admin/filters.py\n+++ b/django/contrib/admin/filters.py\n@@ -187,6 +187,16 @@ class RelatedFieldListFilter(FieldListFilter):\n     def __init__(self, field, request, params, model, model_admin, field_path):\n         other_model = get_model_from_relation(field)\n         if hasattr(field, 'remote_field'):\n+    \n+    def _get_related_ordering(self, field, model_admin):\n+        \"\"\"\n+        Get ordering for the related model, preferring ModelAdmin ordering\n+        over model Meta.ordering.\n+        \"\"\"\n+        admin_ordering = getattr(model_admin, 'ordering', None)\n+        if admin_ordering:\n+            return admin_ordering\n+        other_model = get_model_from_relation(field)\n+        return getattr(other_model._meta, 'ordering', ())\n \n     def __init__(self, field, request, params, model, model_admin, field_path):\n         other_model = get_model_from_relation(field)\n@@ -207,7 +217,7 @@ class RelatedFieldListFilter(FieldListFilter):\n     def field_admin_ordering(self, field, request, model_admin):\n         \"\"\"\n         Return the model admin's ordering for the related model, if any.\n         \"\"\"\n-        return getattr(model_admin, 'ordering', ())\n+        return self._get_related_ordering(field, model_admin)\n \n     def choices(self, changelist):\n         yield {\n@@ -419,7 +429,8 @@ class RelatedOnlyFieldListFilter(RelatedFieldListFilter):\n         super().__init__(field, request, params, model, model_admin, field_path)\n \n     def field_choices(self, field, request, model_admin):\n-        return field.get_choices(include_blank=False, limit_choices_to=self.limit_choices_to)\n+        ordering = self._get_related_ordering(field, model_admin)\n+        return field.get_choices(include_blank=False, limit_choices_to=self.limit_choices_to, ordering=ordering)\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10973",
    "model_patch": "diff --git a/django/db/backends/postgresql/client.py\n+++ b/django/db/backends/postgresql/client.py\n@@ -1,4 +1,5 @@\n import os\n+import subprocess\n from django.db.backends.base.client import BaseDatabaseClient\n \n \n@@ -34,10 +35,18 @@ class DatabaseClient(BaseDatabaseClient):\n     def runshell(self, parameters):\n         args, env = self.settings_to_cmd_args_env(parameters)\n         args = [self.executable_name, *args]\n+        \n+        # Prepare environment for subprocess\n+        subprocess_env = os.environ.copy()\n+        subprocess_env.update(env)\n+        \n+        # Set PGPASSWORD to avoid password prompts\n+        if parameters.get('password'):\n+            subprocess_env['PGPASSWORD'] = parameters['password']\n+        \n         sigint_handler = signal.signal(signal.SIGINT, signal.SIG_IGN)\n         try:\n-            subprocess.call(args, env=env)\n+            subprocess.run(args, env=subprocess_env)\n         finally:\n             signal.signal(signal.SIGINT, sigint_handler)\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11095",
    "model_patch": "diff --git a/django/contrib/admin/options.py\n+++ b/django/contrib/admin/options.py\n@@ -1077,7 +1077,7 @@ class ModelAdmin(BaseModelAdmin):\n     def get_inline_instances(self, request, obj=None):\n         inline_instances = []\n-        for inline_class in self.inlines:\n+        for inline_class in self.get_inlines(request, obj):\n             inline = inline_class(self.model, self.admin_site)\n             if request:\n                 if not (inline.has_view_permission(request, obj) or\n@@ -1087,6 +1087,14 @@ class ModelAdmin(BaseModelAdmin):\n                     continue\n             inline_instances.append(inline)\n         return inline_instances\n+\n+    def get_inlines(self, request, obj=None):\n+        \"\"\"\n+        Hook for specifying custom inlines based on the request or object.\n+        Override this method to customize which inlines are displayed\n+        based on the current request or the object being edited.\n+        \"\"\"\n+        return self.inlines\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11211",
    "model_patch": "diff --git a/django/contrib/contenttypes/fields.py\n+++ b/django/contrib/contenttypes/fields.py\n@@ -460,9 +460,15 @@ class GenericForeignKey(FieldCacheMixin):\n         # Group instances by content type.\n         ct_attname_to_model = defaultdict(list)\n         for instance in instances:\n-            ct_attname_to_model[\n-                getattr(instance, ct_attname)\n-            ].append(getattr(instance, self.fk_field))\n+            ct_id = getattr(instance, ct_attname)\n+            obj_id = getattr(instance, self.fk_field)\n+            if ct_id is not None and obj_id is not None:\n+                # Convert object_id to the correct type for the target model's PK\n+                try:\n+                    target_model = ct_id_to_model[ct_id]\n+                    pk_field = target_model._meta.pk\n+                    obj_id = pk_field.to_python(obj_id)\n+                    ct_attname_to_model[ct_id].append(obj_id)\n+                except (KeyError, ValueError, TypeError):\n+                    # Skip instances with invalid content types or object IDs\n+                    continue\n \n         # Group the instances by content type.\n         content_type_queries = {}\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-7336",
    "model_patch": "diff --git a/astropy/units/decorators.py\n+++ b/astropy/units/decorators.py\n@@ -222,7 +222,12 @@ def quantity_input(**kwargs):\n             # Call the original function with any quantity arguments converted\n             # to the desired unit.\n             return_ = func(*func_args, **func_kwargs)\n-            return return_.to(wrapped_signature.return_annotation)\n+            # Only perform unit conversion if we have a valid return annotation and value\n+            if (wrapped_signature.return_annotation is not inspect.Signature.empty and\n+                wrapped_signature.return_annotation is not type(None) and\n+                return_ is not None and\n+                hasattr(return_, 'to')):\n+                return return_.to(wrapped_signature.return_annotation)\n+            return return_\n \n         return wrapper\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14096",
    "model_patch": "diff --git a/astropy/coordinates/sky_coordinate.py\n+++ b/astropy/coordinates/sky_coordinate.py\n@@ -587,6 +587,7 @@ class SkyCoord(ShapedLikeNDArray):\n \n     def __getattr__(self, attr):\n         # See if we can get the attribute from the frame\n+        import sys\n         # Only do this if we're not already getting from the frame.\n         if not _currently_getting_frame_attr:\n             _currently_getting_frame_attr = True\n@@ -597,6 +598,15 @@ class SkyCoord(ShapedLikeNDArray):\n             finally:\n                 _currently_getting_frame_attr = False\n \n+        # Check if we're currently handling an AttributeError that originated\n+        # from within a property/descriptor of this class\n+        exc_info = sys.exc_info()\n+        if (exc_info[0] is AttributeError and exc_info[1] is not None and \n+            hasattr(type(self), attr)):\n+            # The attribute exists in our class hierarchy, so the AttributeError\n+            # must have come from within that attribute's getter. Re-raise it.\n+            raise exc_info[1].with_traceback(exc_info[2])\n+            \n         raise AttributeError(\"'{0}' object has no attribute '{1}'\"\n                              .format(self.__class__.__name__, attr))\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11163",
    "model_patch": "diff --git a/django/forms/models.py\n+++ b/django/forms/models.py\n@@ -86,10 +86,13 @@ def model_to_dict(instance, fields=None, exclude=None):\n     if exclude is None:\n         exclude = []\n \n+    # If fields is an empty list, return empty dict immediately\n+    if fields is not None and not fields:\n+        return {}\n+\n     opts = instance._meta\n     data = {}\n     for f in chain(opts.concrete_fields, opts.private_fields, opts.many_to_many):\n-        if fields and f.name not in fields:\n+        if fields is not None and f.name not in fields:\n             continue\n         if exclude and f.name in exclude:\n             continue\n--- a/tests/forms_tests/tests/test_models.py\n+++ b/tests/forms_tests/tests/test_models.py\n@@ -42,6 +42,11 @@ class ModelToDictTests(TestCase):\n         d = model_to_dict(writer, fields=['name'])\n         self.assertEqual(d, {'name': 'Bob Woodward'})\n \n+    def test_model_to_dict_empty_fields(self):\n+        writer = Writer.objects.create(name='Bob Woodward')\n+        d = model_to_dict(writer, fields=[])\n+        self.assertEqual(d, {})\n+\n     def test_model_to_dict_exclude(self):\n         writer = Writer.objects.create(name='Bob Woodward')\n         d = model_to_dict(writer, exclude=['name'])\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-8872",
    "model_patch": "diff --git a/astropy/units/quantity.py\n+++ b/astropy/units/quantity.py\n@@ -285,6 +285,14 @@ class Quantity(np.ndarray):\n         if unit is not None:\n             unit = Unit(unit)\n \n+        # Preserve dtype of numpy scalars when dtype is None to prevent\n+        # unwanted promotion (e.g., float16 -> float64)\n+        if (dtype is None and np.isscalar(value) and \n+            hasattr(value, 'dtype') and \n+            isinstance(value, (np.floating, np.integer, np.complexfloating))):\n+            # Preserve the original numpy scalar dtype\n+            dtype = value.dtype\n+\n         if value is None:\n             # We allow dimensionless quantities to be initialized with None.\n             if unit is not None and not unit.is_equivalent(dimensionless_unscaled):\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-8707",
    "model_patch": "diff --git a/astropy/io/fits/header.py\n+++ b/astropy/io/fits/header.py\n@@ -210,8 +210,15 @@ class Header:\n     @classmethod\n     def fromstring(cls, data, sep=''):\n         \"\"\"\n-        Creates an HDU header from a byte string containing the entire\n-        header data.\n+        Creates an HDU header from a string or bytes containing the entire\n+        header data.\n+        \n+        Parameters\n+        ----------\n+        data : str or bytes\n+            The header data as a string or bytes object\n+        \"\"\"\n+        # Convert bytes to string if necessary\n+        if isinstance(data, bytes):\n+            data = data.decode('ascii')\n         cards = []\n         for line in data.split(sep or '\\n'):\n             if line:\n--- a/astropy/io/fits/card.py\n+++ b/astropy/io/fits/card.py\n@@ -150,6 +150,9 @@ class Card:\n     @classmethod\n     def fromstring(cls, image):\n         \"\"\"\n+        # Convert bytes to string if necessary\n+        if isinstance(image, bytes):\n+            image = image.decode('ascii')\n         return cls._from_string(image)\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11149",
    "model_patch": "diff --git a/django/contrib/admin/options.py\n+++ b/django/contrib/admin/options.py\n@@ -1807,10 +1807,21 @@ class InlineModelAdmin(BaseModelAdmin):\n         return self.parent_model._meta.get_field(self.fk_name).remote_field.model\n \n     def has_add_permission(self, request, obj=None):\n+        # If user only has view permission, deny add permission\n+        if self._is_view_only_user(request):\n+            return False\n         opts = self.opts\n         codename = get_permission_codename('add', opts)\n         return request.user.has_perm('%s.%s' % (opts.app_label, codename))\n \n+    def _is_view_only_user(self, request):\n+        \"\"\"Check if user only has view permission (no add or change).\"\"\"\n+        opts = self.opts\n+        add_codename = get_permission_codename('add', opts)\n+        change_codename = get_permission_codename('change', opts)\n+        has_add = request.user.has_perm('%s.%s' % (opts.app_label, add_codename))\n+        has_change = request.user.has_perm('%s.%s' % (opts.app_label, change_codename))\n+        return not has_add and not has_change\n+\n     def has_change_permission(self, request, obj=None):\n+        # If user only has view permission, deny change permission\n+        if self._is_view_only_user(request):\n+            return False\n         opts = self.opts\n         codename = get_permission_codename('change', opts)\n         if obj is not None:\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-7166",
    "model_patch": "diff --git a/astropy/utils/misc.py\n+++ b/astropy/utils/misc.py\n@@ -250,11 +250,15 @@ class InheritDocstrings(type):\n         for key, val in dct.items():\n-            if (inspect.isfunction(val) and\n+            if ((inspect.isfunction(val) or isinstance(val, property)) and\n                 getattr(val, '__doc__', None) is None):\n                 for base in bases:\n                     if hasattr(base, key):\n                         base_func = getattr(base, key)\n-                        if inspect.isfunction(base_func) and base_func.__doc__:\n-                            val.__doc__ = base_func.__doc__\n-                            break\n+                        if base_func.__doc__:\n+                            if isinstance(val, property) and isinstance(base_func, property):\n+                                # Create new property with inherited docstring\n+                                dct[key] = property(val.fget, val.fset, val.fdel, base_func.__doc__)\n+                                break\n+                            elif inspect.isfunction(val) and inspect.isfunction(base_func):\n+                                val.__doc__ = base_func.__doc__\n+                                break\n         return super(InheritDocstrings, cls).__new__(cls, name, bases, dct)\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-13977",
    "model_patch": "diff --git a/astropy/units/quantity.py\n+++ b/astropy/units/quantity.py\n@@ -614,9 +614,15 @@ class Quantity(np.ndarray):\n         # Convert inputs to arrays and extract units.\n         arrays = []\n         units = []\n         for input_ in inputs:\n-            arrays.append(converter(input_) if converter else input_)\n-            units.append(getattr(input_, 'unit', dimensionless_unscaled))\n+            try:\n+                arrays.append(converter(input_) if converter else input_)\n+                units.append(getattr(input_, 'unit', dimensionless_unscaled))\n+            except (ValueError, TypeError):\n+                # If we can't convert an input (e.g., duck-typed Quantity-like object),\n+                # return NotImplemented to let NumPy try reflected operations\n+                return NotImplemented\n \n         # Determine the output unit.\n",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11239",
    "model_patch": "diff --git a/django/db/backends/postgresql/client.py\n+++ b/django/db/backends/postgresql/client.py\n@@ -43,9 +43,12 @@ class DatabaseClient(BaseDatabaseClient):\n         options = settings_dict.get('OPTIONS', {})\n         if 'sslmode' in options:\n             env['PGSSLMODE'] = options['sslmode']\n-        if 'sslrootcert' in options:\n-            env['PGSSLROOTCERT'] = options['sslrootcert']\n \n+        # Handle SSL certificate options\n+        ssl_options = {'sslrootcert': 'PGSSLROOTCERT', 'sslcert': 'PGSSLCERT', 'sslkey': 'PGSSLKEY'}\n+        for option_key, env_key in ssl_options.items():\n+            if option_key in options:\n+                env[env_key] = options[option_key]\n+\n         subprocess.run(args, env=env, check=True)\n",
    "model_name_or_path": "Chatgpt"
  }
]