[
  {
    "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,40 @@ 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+        # Validate input dimensions\n+        if len(world_arrays) != len(self._world_keep):\n+            raise ValueError(f\"Expected {len(self._world_keep)} world coordinates, \"\n+                           f\"got {len(world_arrays)}\")\n+        \n+        # Reconstruct full world coordinate arrays\n         world_arrays_full = [None] * self._wcs.world_n_dim\n-        iworld = 0\n+        \n+        # Build reverse mapping from original world axis to sliced world axis\n+        world_axis_mapping = {}\n+        for sliced_idx, orig_idx in enumerate(self._world_keep):\n+            world_axis_mapping[orig_idx] = sliced_idx\n+        \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+            if iworld_full in world_axis_mapping:\n+                # Use input world coordinate for this axis\n+                sliced_idx = world_axis_mapping[iworld_full]\n+                world_arrays_full[iworld_full] = world_arrays[sliced_idx]\n             else:\n+                # Use fixed slice value for this axis\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 kept dimensions in correct order\n         pixel_arrays = []\n-        for ipixel_full in self._pixel_keep:\n-            pixel_arrays.append(pixel_arrays_full[ipixel_full])\n+        for ipixel_kept in self._pixel_keep:\n+            if ipixel_kept < len(pixel_arrays_full):\n+                pixel_arrays.append(pixel_arrays_full[ipixel_kept])\n+            else:\n+                raise IndexError(f\"Pixel index {ipixel_kept} out of range for \"\n+                               f\"full WCS with {len(pixel_arrays_full)} dimensions\")\n \n         return pixel_arrays",
    "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,25 @@ class NDArithmeticMixin:\n         if handle_mask is None:\n             return None\n \n+        # Early return for cases with None masks\n+        if mask1 is None and mask2 is None:\n+            return None\n+        \n+        # If one mask is None, we need to handle it based on the operation\n+        if mask1 is None or mask2 is None:\n+            non_none_mask = mask1 if mask1 is not None else mask2\n+            \n+            # For bitwise operations, create a zero mask for the None operand\n+            if handle_mask in (np.bitwise_or, np.bitwise_and, np.bitwise_xor):\n+                zero_mask = np.zeros_like(non_none_mask, dtype=bool)\n+                if mask1 is None:\n+                    mask1 = zero_mask\n+                else:\n+                    mask2 = zero_mask\n+            else:\n+                # For other operations, just return the existing mask\n+                return deepcopy(non_none_mask)\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)",
    "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,12 @@ class Query:\n         query = Query(self.model)\n         query.add_filter(filter_expr)\n         query.clear_ordering(True)\n+        # Preserve annotation context for exclude operations\n+        query.annotations = self.annotations.copy()\n+        query._filtered_relations = self._filtered_relations.copy()\n+        # Also copy extra context that might be needed\n+        if hasattr(self, 'extra') and self.extra:\n+            query.extra = self.extra.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)",
    "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,16 @@ 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 values when decimal_pos is specified\n+        if decimal_pos is not None:\n+            try:\n+                # Try to quantize to the specified decimal places\n+                quantized = number.quantize(Decimal('0.1') ** decimal_pos)\n+                if quantized == 0 and number != 0:\n+                    # Number is too small to represent at this precision\n+                    sign = '-' if number < 0 else ''\n+                    return sign + '0' + decimal_sep + '0' * decimal_pos\n+            except (InvalidOperation, Overflow):\n+                pass\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:",
    "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\n+    from distutils.version import StrictVersion as parse_version\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)",
    "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,5 @@ 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+if len(args) > 0:\n+    return isinstance(args[0], (HDUList, TableHDU, BinTableHDU, GroupsHDU))\n+return False",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10554",
    "model_patch": "diff --git a/django/db/models/sql/compiler.py\n+++ b/django/db/models/sql/compiler.py\n@@ -900,6 +900,15 @@ class SQLCompiler:\n         if self.query.extra_order_by:\n             ordering.extend(self.query.extra_order_by)\n         if not ordering:\n+            # For compound queries, don't apply default ordering that might\n+            # reference columns not in the SELECT list\n+            if self.query.combinator:\n+                return []\n+            \n+            # Check if this is a compound query with ordering issues\n+            if (self.query.combinator and self.query.order_by and \n+                any(isinstance(item, int) for item in self.query.order_by)):\n+                return []\n             ordering = self.query.get_meta().ordering or []\n         if self.query.standard_ordering:\n             asc, desc = ORDER_DIR['ASC'], ORDER_DIR['DESC']\n@@ -920,6 +929,12 @@ class SQLCompiler:\n                     continue\n                 if col in self.query.annotation_select:\n                     continue\n+                # For compound queries, skip ordering by fields not in select list\n+                if self.query.combinator:\n+                    select_fields = [alias for alias, _ in self.query.annotation_select.items()]\n+                    select_fields.extend([f.target.column for f in self.query.select if hasattr(f.target, 'column')])\n+                    if field not in select_fields:\n+                        continue\n                 if self.query.group_by is True:\n                     raise FieldError('Cannot resolve keyword %r into field. '\n                                      'Choices are: %s' % (field,",
    "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",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11138",
    "model_patch": "diff --git a/django/db/backends/mysql/operations.py\n+++ b/django/db/backends/mysql/operations.py\n@@ -70,7 +70,12 @@ 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+            # Get the database timezone\n+            db_timezone = getattr(self.connection, 'timezone_name', 'UTC')\n+            \n+            # Only convert if database timezone differs from target timezone\n+            if db_timezone != tzname:\n+                field_name = \"CONVERT_TZ(%s, '%s', '%s')\" % (field_name, db_timezone, tzname)\n         return \"CAST(%s AS DATE)\" % field_name\n \n     def datetime_extract_sql(self, lookup_type, field_name, tzname):\n@@ -78,7 +83,12 @@ 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+                # Get the database timezone\n+                db_timezone = getattr(self.connection, 'timezone_name', 'UTC')\n+                \n+                # Only convert if database timezone differs from target timezone\n+                if db_timezone != tzname:\n+                    field_name = \"CONVERT_TZ(%s, '%s', '%s')\" % (field_name, db_timezone, 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 +96,12 @@ 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+                # Get the database timezone\n+                db_timezone = getattr(self.connection, 'timezone_name', 'UTC')\n+                \n+                # Only convert if database timezone differs from target timezone\n+                if db_timezone != tzname:\n+                    field_name = \"CONVERT_TZ(%s, '%s', '%s')\" % (field_name, db_timezone, tzname)\n         fields = {\n             'year': '%%Y-01-01',\n             'month': '%%Y-%%m-01',",
    "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@@ -68,9 +68,9 @@ class URLValidator(RegexValidator):\n     ul = '\\u00a1-\\uffff'  # unicode letters range (must not be a raw string)\n \n     regex = re.compile(\n-        r'^(?:http|ftp)s?://'  # http:// or https://\n-        r'(?:(?P<user>[^\\s:/@]+)(?::(?P<pass>[^\\s:/@]+))?@)?'  # user:pass@\n-        r'(?:(?:[A-Z0-9](?:[A-Z0-9-]{0,61}[A-Z0-9])?\\.)+'  # domain...\n+        r'^(?:http|ftp)s?://'  # scheme\n+        r'(?:(?P<user>[A-Za-z0-9._~!$&\\'()*+,;=%-]+)(?::(?P<pass>[A-Za-z0-9._~!$&\\'()*+,;=%-]+))?@)?'  # userinfo with proper encoding\n+        r'(?:(?:[A-Z0-9](?:[A-Z0-9-]{0,61}[A-Z0-9])?\\.)+'  # domain...\n         r'(?:[A-Z]{2,6}\\.?|[A-Z0-9-]{2,}\\.?)|'  # host...\n         r'localhost|'  # localhost...\n         r'\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3})'  # ...or ip",
    "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,8 @@\n \n     def __eq__(self, other):\n+        if other is None or not isinstance(other, (str, Unit)):\n+            return False\n         other = Unit(other, parse_strict='silent')\n         return isinstance(other, UnrecognizedUnit) and self.name == other.name",
    "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\n \n \n class RSTHeader(FixedWidthHeader):\n@@ -85,15 +86,32 @@ 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 multiple header rows if specified\n+        if hasattr(self.parent_table, '_header_rows') and self.parent_table._header_rows:\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+                header_lines.append(col.info.name)\n+            return [header_lines]\n \n-        return lines\n+        return lines\n \n \n class RSTData(FixedWidthData):",
    "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@@ -276,12 +276,18 @@ class Collector:\n         with transaction.atomic(using=self.using, savepoint=False):\n             # send pre_delete signals\n             for model, obj in self.instances_with_model():\n                 if not model._meta.auto_created:\n                     signals.pre_delete.send(\n                         sender=model, instance=obj, using=self.using\n                     )\n \n+            # Track instances to nullify PKs after deletion\n+            instances_to_nullify = []\n+            for model, instances in self.data.items():\n+                instances_to_nullify.extend(instances)\n+            for qs in self.fast_deletes:\n+                if hasattr(qs, '_result_cache') and qs._result_cache:\n+                    instances_to_nullify.extend(qs._result_cache)\n+\n             # fast deletes\n             for qs in self.fast_deletes:\n                 count = qs._raw_delete(using=self.using)\n@@ -294,6 +300,10 @@ class Collector:\n                 count = query.delete_batch(pk_list, self.using)\n                 if count:\n                     deleted_counter[model._meta.label] += count\n+            \n+            # Set PK to None for all deleted instances\n+            for instance in instances_to_nullify:\n+                setattr(instance, instance._meta.pk.attname, None)\n \n         # update collected instances\n         for instances_for_fieldvalues in self.field_updates.values():",
    "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)",
    "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,12 @@ 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+                # Use the standard column formatting method\n+                formatted_value = self._format_col_str(col, value)\n+                lines.append('<td>{}</td>'.format(formatted_value))\n             lines.append('</tr>')\n+        \n         lines.append('</table>')\n         lines.append('</body>')\n         lines.append('</html>')",
    "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@@ -420,7 +420,8 @@ class Card:\n             # Add quotes around the value\n             value_str = \"'\" + value_str + \"'\"\n         else:\n-            value_str = \"'\" + value_str.replace(\"'\", \"''\") + \"'\"\n+            # Escape single quotes by doubling them, preserving the FITS standard\n+            value_str = \"'\" + value_str.replace(\"'\", \"''\") + \"'\"\n \n         # Format the card string\n         if self.comment:\n@@ -485,7 +486,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",
    "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 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)",
    "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;",
    "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",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-14539",
    "model_patch": "diff --git a/astropy/io/fits/hdu/table.py\n+++ b/astropy/io/fits/hdu/table.py\n@@ -1450,6 +1450,15 @@ def _get_vla_format(format_):\n     if format_[0] in ('P', 'Q'):\n         # Variable length array format\n         max_len = format_[1:]\n+        \n+        # Ensure consistent format representation\n+        if max_len == '':\n+            max_len = '0'\n+        \n+        # Normalize the format string to ensure consistency\n+        base_format = format_[0]\n+        format_ = f\"{base_format}{max_len}\"\n+        \n         if max_len == '':\n             max_len = 0\n         else:\n@@ -1460,7 +1469,10 @@ def _get_vla_format(format_):\n             max_len = int(max_len)\n         \n         # Return the format with consistent descriptor\n-        return format_, max_len\n+        # Ensure the returned format is canonical\n+        canonical_format = f\"{base_format}{max_len if max_len > 0 else ''}\"\n+        \n+        return canonical_format, max_len\n     \n     return format_, None",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-13398",
    "model_patch": "diff --git a/astropy/coordinates/__init__.py\n+++ b/astropy/coordinates/__init__.py\n@@ -50,6 +50,9 @@ from .builtin_frames import *\n # Import the transformation machinery\n from .transformations import *\n \n+# Import direct ITRS transformations\n+from . import itrs_direct_transforms\n+\n # Import other utilities that are useful to users\n from .name_resolve import *\n from .matching import *",
    "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,9 @@ 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', help='Skip system checks.'\n+        )\n \n     def add_arguments(self, parser):\n         \"\"\"\n@@ -415,6 +418,8 @@ class BaseCommand:\n         options, args = parser.parse_known_args(argv[2:])\n         cmd_options = vars(options)\n         handle_default_options(options)\n+        # Ensure skip_checks option is available\n+        cmd_options.setdefault('skip_checks', False)\n         return self.execute(*args, **cmd_options)\n \n     def execute(self, *args, **options):\n@@ -305,6 +310,7 @@ class BaseCommand:\n         \"\"\"\n         options = options or {}\n         options.setdefault('verbosity', self.verbosity)\n+        # Respect the skip_checks option from command line\n \n         if self.requires_system_checks and not options.get('skip_checks'):\n             if self.requires_system_checks == ALL_CHECKS:",
    "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@@ -140,7 +140,18 @@ class Collector:\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+        # For deletion operations, only fetch primary key to avoid\n+        # UnicodeDecodeError on problematic text fields\n+        model = field.model\n+        pk_name = model._meta.pk.name\n+        \n+        # Also include foreign key fields that might be needed for cascading\n+        fk_fields = [f.name for f in model._meta.get_fields() \n+                    if (f.many_to_one or f.one_to_one) and hasattr(f, 'name')]\n+        essential_fields = [pk_name] + fk_fields\n+        \n+        return queryset.only(*essential_fields)",
    "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@@ -22,10 +22,11 @@ class RenameContentType:\n     def _rename(self, apps, schema_editor, old_model, new_model):\n         ContentType = apps.get_model('contenttypes', 'ContentType')\n         db = schema_editor.connection.alias\n+        db_alias = db  # Store for consistency\n         try:\n-            content_type = ContentType.objects.using(db).get_by_natural_key(app_label, old_model)\n+            content_type = ContentType.objects.using(db_alias).get_by_natural_key(app_label, old_model)\n         except ContentType.DoesNotExist:\n             pass\n         else:\n             content_type.model = new_model\n-            with transaction.atomic(using=db):\n-                content_type.save(update_fields={'model'})\n+            with transaction.atomic(using=db_alias):\n+                content_type.save(using=db_alias, update_fields={'model'})",
    "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 ''",
    "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",
    "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@@ -1440,6 +1440,13 @@ 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+            from warnings import warn\n+            warn(\n+                \"Automatic conversion of structured numpy arrays to NdarrayMixin \"\n+                \"is deprecated. In astropy 5.2, structured arrays will be added \"\n+                \"as Column instances directly. To avoid this warning, wrap your \"\n+                \"data in Column() explicitly.\",\n+                FutureWarning, stacklevel=3)\n             data = data.view(NdarrayMixin)\n             data_is_mixin = True",
    "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,7 @@ 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         try:\n             return template.render(context, request)\n         except TemplateDoesNotExist:\ndiff --git a/django/template/context.py\n+++ b/django/template/context.py\n@@ -32,11 +32,12 @@ class Context:\n     \"\"\"\n     A stack container for variable context\n     \"\"\"\n-    def __init__(self, dict_=None, current_app=None, use_l10n=None, use_tz=None):\n+    def __init__(self, dict_=None, current_app=None, use_l10n=None, use_tz=None, autoescape=True):\n         self.dicts = [{}]\n         self.current_app = current_app\n         self.use_l10n = use_l10n\n         self.use_tz = use_tz\n+        self.autoescape = autoescape\n         if dict_ is not None:\n             self.dicts = [dict_]",
    "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 = f'DISTINCT {sql}'\n         return self.filter(\n             extra_context={'distinct': self.distinct},\n             template=template % sql,",
    "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@@ -17,7 +17,9 @@ class ModelBackend(BaseBackend):\n \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:",
    "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'(?-m)^[\\w.@+-]+$',\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'(?-m)^[\\w.@+-]+$',\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",
    "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)",
    "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):",
    "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@@ -556,6 +556,7 @@ def split_cds_units(unit):\n     \"\"\"\n     import re\n     from astropy import units as u\n+    \n \n     if unit is None:\n         return None\n@@ -570,6 +571,25 @@ def split_cds_units(unit):\n     # Replace ^ with **\n     unit = unit.replace('^', '**')\n \n+    # Fix CDS unit parsing for composite units\n+    def fix_cds_unit_string(unit_str):\n+        # Pattern to match scale factor and unit parts\n+        pattern = r'^(10[+-]?\\d+)?(.*)$'\n+        match = re.match(pattern, unit_str)\n+        \n+        if match:\n+            scale_part, unit_part = match.groups()\n+            \n+            # Convert scale notation\n+            if scale_part:\n+                scale_part = scale_part.replace('10+', '1e').replace('10-', '1e-')\n+                if not scale_part.startswith('1e'):\n+                    scale_part = scale_part.replace('10', '1e')\n+                scale_part += '*'\n+            else:\n+                scale_part = ''\n+            \n+            # Handle multiple divisions by grouping denominator\n+            if unit_part and unit_part.count('/') > 1:\n+                parts = unit_part.split('/')\n+                numerator = parts[0]\n+                denominators = parts[1:]\n+                unit_part = f'{numerator}/({\"*\".join(denominators)})'\n+            \n+            return f'{scale_part}{unit_part}'\n+        \n+        return unit_str\n+    \n+    unit = fix_cds_unit_string(unit)\n+\n     try:\n         return u.Unit(unit)\n     except (ValueError, TypeError):",
    "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     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@@ -95,9 +95,18 @@ def _traverse_model_graph(model, inputs, outputs):\n             outputs.extend(range(n_outputs))\n         else:\n             # Handle compound models\n-            for submodel_name in model.submodel_names:\n-                submodel = getattr(model, submodel_name)\n-                _traverse_model_graph(submodel, inputs, outputs)\n+            current_input_offset = len(inputs)\n+            current_output_offset = len(outputs)\n+            \n+            for i, submodel_name in enumerate(model.submodel_names):\n+                submodel = getattr(model, submodel_name)\n+                if isinstance(submodel, CompoundModel):\n+                    # Recursively handle nested compound models\n+                    _traverse_model_graph(submodel, inputs, outputs)\n+                else:\n+                    # Handle atomic models\n+                    sub_inputs = list(range(current_input_offset, current_input_offset + submodel.n_inputs))\n+                    sub_outputs = list(range(current_output_offset, current_output_offset + submodel.n_outputs))\n+                    inputs.extend(sub_inputs)\n+                    outputs.extend(sub_outputs)\n+                    current_input_offset += submodel.n_inputs\n+                    current_output_offset += submodel.n_outputs",
    "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@@ -1,6 +1,7 @@\n # Licensed under a 3-clause BSD style license - see LICENSE.rst\n \"\"\"An extensible ASCII table reader and writer.\"\"\"\n \n+import re\n from astropy.table import Table\n from . import basic\n from . import core\n@@ -248,17 +249,17 @@ class QDP(basic.Basic):\n         \n         for line in lines:\n             line = line.strip()\n             if not line:\n                 continue\n             \n-            if line.startswith('READ SERR'):\n+            if re.match(r'^read\\s+serr', line, re.IGNORECASE):\n                 # Handle error column specification\n                 pass\n-            elif line.startswith('READ TERR'):\n+            elif re.match(r'^read\\s+terr', line, re.IGNORECASE):\n                 # Handle time error specification\n                 pass\n-            elif line.startswith('READ'):\n+            elif re.match(r'^read\\b', line, re.IGNORECASE):\n                 # Handle other READ commands\n                 pass\n-            elif line.startswith('!'):\n+            elif line.startswith('!'):\n                 # Comment line\n                 continue\n             else:",
    "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)",
    "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@@ -37,7 +38,11 @@ class DatabaseClient(BaseDatabaseClient):\n         args = [self.executable_name, *self.settings_to_cmd_args_env(parameters)[0]]\n         sigint_handler = signal.signal(signal.SIGINT, signal.SIG_IGN)\n         try:\n-            subprocess.call(args, env=env)\n+            # Use subprocess.run with PGPASSWORD in environment\n+            run_env = {**os.environ, **env}\n+            if parameters.get('password'):\n+                run_env['PGPASSWORD'] = parameters['password']\n+            subprocess.run(args, env=run_env)\n         finally:\n             signal.signal(signal.SIGINT, sigint_handler)",
    "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,12 @@ 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+        \"\"\"\n+        return self.inlines",
    "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@@ -470,8 +470,18 @@ 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+            # Get the target model and its primary key field\n+            target_model = ct_id_to_model[ct_id]\n+            pk_field = target_model._meta.pk\n+            \n+            # Convert object_id values to the correct type, filtering out None values\n+            converted_fkeys = []\n+            for obj_id in fkey:\n+                if obj_id is not None:\n+                    converted_fkeys.append(pk_field.to_python(obj_id))\n+            \n             content_type_queries[ct_id] = (\n-                ct_id_to_model[ct_id]._base_manager.filter(\n-                    pk__in=fkey\n+                target_model._base_manager.filter(\n+                    pk__in=converted_fkeys\n                 ),\n-                fkey\n+                converted_fkeys\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+            try:\n+                return return_.to(wrapped_signature.return_annotation)\n+            except AttributeError:\n+                # Handle case where return_ is None (e.g., constructors)\n+                # or doesn't have a .to() method\n+                return return_\n \n         return wrapper",
    "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,16 @@ class SkyCoord(ShapedLikeNDArray):\n             finally:\n                 _currently_getting_frame_attr = False\n \n+        # Check if this AttributeError came from within a property/descriptor\n+        # by examining the current exception context\n+        exc_info = sys.exc_info()\n+        if exc_info[0] is AttributeError and exc_info[2] is not None:\n+            # Walk up the traceback to see if we're inside a property getter\n+            tb = exc_info[2]\n+            while tb.tb_next is not None:\n+                tb = tb.tb_next\n+            if tb.tb_frame.f_code.co_name in ('__get__', 'fget') or 'property' in str(tb.tb_frame.f_code):\n+                raise exc_info[1].with_traceback(exc_info[2])\n         raise AttributeError(\"'{0}' object has no attribute '{1}'\"\n                              .format(self.__class__.__name__, attr))",
    "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",
    "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,11 @@ 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\n+        if dtype is None and np.isscalar(value) and hasattr(value, 'dtype'):\n+            # This is a numpy scalar, preserve its 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@@ -960,6 +965,11 @@ class Quantity(np.ndarray):\n         if dtype is None:\n             dtype = getattr(value, 'dtype', None)\n \n+        # Preserve dtype of numpy scalars to avoid unwanted promotion\n+        if dtype is None and np.isscalar(value) and hasattr(value, 'dtype'):\n+            # This is a numpy scalar, preserve its dtype\n+            dtype = value.dtype\n+\n         if unit is not None:\n             unit = Unit(unit)",
    "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+        diff --gitdiff --gitdiff --git-\n+        data : str or bytes\n+            The header data as a string or bytes object\n+        \"\"\"\n+        if isinstance(data, bytes):\n+            data = data.decode('ascii')\n         cards = []\n         for line in data.split(sep or '\\n'):\n             if line:",
    "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@@ -1810,7 +1810,11 @@ class InlineModelAdmin(BaseModelAdmin):\n     def has_add_permission(self, request, obj=None):\n         opts = self.opts\n         codename = get_permission_codename('add', opts)\n-        return request.user.has_perm('%s.%s' % (opts.app_label, codename))\n+        has_add = request.user.has_perm('%s.%s' % (opts.app_label, codename))\n+        # For view-only users, check if they also lack change permission\n+        if not has_add:\n+            change_codename = get_permission_codename('change', opts)\n+            return request.user.has_perm('%s.%s' % (opts.app_label, change_codename))\n+        return has_add\n \n     def has_change_permission(self, request, obj=None):\n         opts = self.opts\n@@ -1820,7 +1824,11 @@ class InlineModelAdmin(BaseModelAdmin):\n             return request.user.has_perm(\n                 '%s.%s' % (opts.app_label, codename), obj\n             )\n-        return request.user.has_perm('%s.%s' % (opts.app_label, codename))\n+        has_change = request.user.has_perm('%s.%s' % (opts.app_label, codename))\n+        # For view-only users, check if they also lack add permission\n+        if not has_change:\n+            add_codename = get_permission_codename('add', opts)\n+            return request.user.has_perm('%s.%s' % (opts.app_label, add_codename))\n+        return has_change",
    "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,7 +250,7 @@ class InheritDocstrings(type):\n         for key, val in dct.items():\n             if (inspect.isfunction(val) 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+            elif isinstance(val, property) and getattr(val, '__doc__', None) is None:\n+                for base in bases:\n+                    if hasattr(base, key):\n+                        base_attr = getattr(base, key)\n+                        if isinstance(base_attr, property) and base_attr.__doc__:\n+                            # Create new property with inherited docstring\n+                            dct[key] = property(\n+                                fget=val.fget,\n+                                fset=val.fset, \n+                                fdel=val.fdel,\n+                                doc=base_attr.__doc__\n+                            )\n+                            break",
    "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,19 @@ 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, but we can't handle it\n+                # Let NumPy try the reflected operation\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.",
    "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@@ -46,6 +46,10 @@ class DatabaseClient(BaseDatabaseClient):\n         if 'sslrootcert' in options:\n             env['PGSSLROOTCERT'] = options['sslrootcert']\n \n+        if 'sslcert' in options:\n+            env['PGSSLCERT'] = options['sslcert']\n+        if 'sslkey' in options:\n+            env['PGSSLKEY'] = options['sslkey']\n+\n         subprocess.run(args, env=env, check=True)",
    "model_name_or_path": "Chatgpt"
  }
]