[
  {
    "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 to LooseVersion for environments without packaging\n+    from distutils.version import LooseVersion as _LooseVersion\n+    parse_version = lambda v: _LooseVersion(str(v))\n \n from astropy.utils.exceptions import AstropyDeprecationWarning\n \n@@ -143,6 +148,6 @@ 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 parse_version(have_version) >= parse_version(version)\n     else:\n-        return LooseVersion(have_version) > LooseVersion(version)\n+        return parse_version(have_version) > parse_version(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,16 @@ 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 that need element-wise comparison\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+                return self._array_compare(a_arr, b_arr)\n+            except (ValueError, TypeError):\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,25 @@ class CheckConstraint(BaseConstraint):\n         return schema_editor._check_sql(self.name, check)\n \n     def _get_check_sql(self, model, schema_editor):\n+        class ColToSimpleColTransformer:\n+            \"\"\"Transform Col nodes to SimpleCol nodes in expression tree.\"\"\"\n+            \n+            def transform(self, expr):\n+                if hasattr(expr, 'clone'):\n+                    expr = expr.clone()\n+                \n+                # Transform children first\n+                if hasattr(expr, 'children'):\n+                    expr.children = [self.transform(child) for child in expr.children]\n+                \n+                # Replace Col with SimpleCol\n+                if expr.__class__.__name__ == 'Col':\n+                    from django.db.models.expressions import SimpleCol\n+                    return SimpleCol(expr.target, expr.output_field)\n+                \n+                return expr\n+        \n+        transformer = ColToSimpleColTransformer()\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 +176,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 = transformer.transform(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,14 @@ 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+        # Try both default string and formatted string, choose the shorter one\n+        str_repr = str(value)\n+        formatted_repr = f\"{value:.16G}\"\n+        \n+        # Use the shorter representation, preferring str() in case of tie\n+        if len(str_repr) <= len(formatted_repr):\n+            return str_repr\n+        return formatted_repr\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+            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,10 @@ 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+        # Don't make database queries when username is None\n+        # This avoids unnecessary queries when credentials are for another backend\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",
    "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,28 @@ def split_cds_units(unit):\n     # Replace ^ with **\n     unit = unit.replace('^', '**')\n \n+    # Handle CDS-style composite units with proper operator precedence\n+    if '/' in unit:\n+        # Extract scale factor if present (e.g., 10+3, 10-7)\n+        scale_match = re.match(r'^(10[+-]?\\d+)(.*)$', unit)\n+        scale_factor = ''\n+        unit_part = unit\n+        \n+        if scale_match:\n+            scale_str, unit_part = scale_match.groups()\n+            # Convert 10+3 or 10-7 to 1e3 or 1e-7\n+            if '+' in scale_str:\n+                scale_str = scale_str.replace('10+', '1e')\n+            elif '-' in scale_str:\n+                scale_str = scale_str.replace('10-', '1e-')\n+            else:\n+                scale_str = scale_str.replace('10', '1e')\n+            scale_factor = scale_str + '*'\n+        \n+        # Handle multiple divisions by grouping denominator terms\n+        if unit_part.count('/') > 1:\n+            parts = unit_part.split('/')\n+            numerator = parts[0]\n+            denominator_parts = parts[1:]\n+            unit_part = f'{numerator}/({\\\"*\\\".join(denominator_parts)})'\n+        \n+        unit = scale_factor + unit_part\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,8 @@ 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 +96,21 @@ def _traverse_model_graph(model, inputs, outputs):\n             outputs.extend(range(n_outputs))\n         else:\n             # Handle compound models\n+            input_offset = len(inputs)\n+            output_offset = 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+                    # Recursively handle nested compound models\n+                    _traverse_model_graph(submodel, inputs, outputs)\n+                else:\n+                    # Handle atomic models - add their inputs/outputs with proper offsets\n+                    sub_inputs = list(range(input_offset, input_offset + submodel.n_inputs))\n+                    sub_outputs = list(range(output_offset, output_offset + submodel.n_outputs))\n+                    inputs.extend(sub_inputs)\n+                    outputs.extend(sub_outputs)\n+                    input_offset += submodel.n_inputs\n+                    output_offset += 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,11 @@ 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+\n def _get_type_from_list_of_lines(lines, delimiter=None):\n     \"\"\"\n     Scan the lines to determine table type.\n@@ -179,17 +184,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 any(_command_matches(line, cmd) for cmd in [\"SKIP\", \"NO\", \"PLOT\", \"TIME\", \"LST\", \"LAB\"]):\n             # Other QDP commands\n             continue\n         else:\n@@ -248,7 +253,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 +323,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@@ -207,7 +207,12 @@ class RelatedFieldListFilter(FieldListFilter):\n \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+        Return the model admin's ordering for the related model, or fall back\n+        to the related model's Meta.ordering if no admin ordering is defined.\n         \"\"\"\n-        return getattr(model_admin, 'ordering', ())\n+        admin_ordering = getattr(model_admin, 'ordering', None)\n+        if admin_ordering is not None:\n+            return admin_ordering\n+        other_model = get_model_from_relation(field)\n+        return getattr(other_model._meta, 'ordering', ())\n \n     def choices(self, changelist):\n         yield {\n@@ -419,7 +424,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.field_admin_ordering(field, request, 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@@ -440,6 +440,18 @@ class GenericForeignKey(FieldCacheMixin):\n         return self.remote_field.model._meta.get_field(self.object_id_field_name)\n \n     def get_prefetch_queryset(self, instances, queryset=None):\n+        def _convert_object_ids(object_ids, target_model):\n+            \"\"\"Convert object_id values to the correct type for the target model's PK.\"\"\"\n+            pk_field = target_model._meta.pk\n+            converted_ids = []\n+            for obj_id in object_ids:\n+                if obj_id is not None:\n+                    try:\n+                        converted_ids.append(pk_field.to_python(obj_id))\n+                    except (ValueError, TypeError):\n+                        # Skip invalid object IDs\n+                        continue\n+            return converted_ids\n+        \n         if queryset is not None:\n             raise ValueError(\"Custom queryset can't be used for this lookup.\")\n \n@@ -470,6 +482,9 @@ class GenericForeignKey(FieldCacheMixin):\n         # Group the instances by content type.\n         content_type_queries = {}\n         for ct_id, fkey in ct_attname_to_model.items():\n+            target_model = ct_id_to_model[ct_id]\n+            # Convert object_id values to the correct type\n+            fkey = _convert_object_ids(fkey, target_model)\n             content_type_queries[ct_id] = (\n-                ct_id_to_model[ct_id]._base_manager.filter(\n+                target_model._base_manager.filter(\n                     pk__in=fkey\n                 ),\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,18 @@ 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+            # Check if input is a duck-typed object that might not be convertible\n+            if (hasattr(input_, '__array_ufunc__') and \n+                not isinstance(input_, (np.ndarray, Quantity)) and\n+                hasattr(input_, 'unit')):\n+                # This looks like a duck-typed Quantity, let NumPy try reflected operations\n+                return NotImplemented\n+            \n+            try:\n+                arrays.append(converter(input_) if converter else input_)\n+                units.append(getattr(input_, 'unit', dimensionless_unscaled))\n+            except (ValueError, TypeError):\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"
  }
]