[
  {
    "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,28 @@ 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 dimensionality, preserving order\n         world_arrays_full = [None] * self._wcs.world_n_dim\n-        iworld = 0\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+        \n+        # Create mapping from kept world indices to input indices\n+        kept_to_input = {kept_idx: i for i, kept_idx in enumerate(self._world_keep)}\n+        \n+        for iworld_full in range(self._wcs.world_n_dim):\n+            if iworld_full in kept_to_input:\n+                world_arrays_full[iworld_full] = world_arrays[kept_to_input[iworld_full]]\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-        pixel_arrays = []\n-        for ipixel_full in self._pixel_keep:\n-            pixel_arrays.append(pixel_arrays_full[ipixel_full])\n+        # Extract pixel coordinates maintaining the order of kept dimensions\n+        return self._map_output(pixel_arrays_full)\n+\n+    def _map_output(self, pixel_arrays_full):\n+        \"\"\"Map full pixel arrays to sliced pixel arrays.\"\"\"\n+        pixel_arrays = []\n+        for ipixel_kept in self._pixel_keep:\n+            pixel_arrays.append(pixel_arrays_full[ipixel_kept])\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,16 @@ class NDArithmeticMixin:\n         if handle_mask is None:\n             return None\n \n+        # Handle None masks before applying the mask function\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+        # Both masks are not None, proceed with normal handling\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@@ -1599,7 +1599,9 @@ class Query:\n         # Generate the inner query.\n         query = Query(self.model)\n         query.add_filter(filter_expr)\n+        # Copy annotations and filtered relations from the original query\n+        query.annotations = self.annotations.copy()\n+        query._filtered_relations = self._filtered_relations.copy()\n         query.clear_ordering(True)\n         # Try to have as simple as possible subquery -> trim leading joins from\n         # the subquery.",
    "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,13 @@ def _format(number, decimal_sep, decimal_pos=None, grouping=0, thousand_sep='',\n     # sign\n     sign = ''\n     if isinstance(number, Decimal):\n+        # When decimal_pos is specified, check if the number is too small to represent\n+        # at the given precision and return formatted zero instead of exponential notation\n+        if decimal_pos is not None and number != 0:\n+            threshold = Decimal(10) ** (-decimal_pos)\n+            if abs(number) < threshold:\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:",
    "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,7 @@\n import inspect\n import sys\n import warnings\n+from packaging.version import Version\n \n from astropy.utils.exceptions import AstropyDeprecationWarning\n \n@@ -143,6 +144,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 Version(have_version) >= Version(version)\n     else:\n-        return LooseVersion(have_version) > LooseVersion(version)\n+        return Version(have_version) > 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,4 @@ 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+return args and isinstance(args[0], (HDUList, TableHDU, BinTableHDU, GroupsHDU))",
    "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@@ -1000,6 +1000,13 @@ 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 (union, intersection, difference), clear any existing\n+        # ordering that might reference 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+            # Clear existing ordering to prevent conflicts with new ordering\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",
    "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,12 +90,8 @@ 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+                # Import migrations module - pkgutil.iter_modules will handle discovery\n+                import_module('%s.migrations' % app_config.name)",
    "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@@ -46,7 +46,15 @@ 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+                # Get the database timezone\n+                db_timezone = getattr(self.connection, 'timezone_name', 'UTC')\n+                \n+                # If database timezone equals target timezone, no conversion needed\n+                if db_timezone == timezone_name:\n+                    return field_name\n+                else:\n+                    return \"CONVERT_TZ(%s, '%s', '%s')\" % (\n+                        field_name, db_timezone, timezone_name)\n         return field_name\n \n     def datetime_cast_date_sql(self, field_name, tzname):",
    "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@@ -70,7 +70,7 @@ class URLValidator(RegexValidator):\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'(?:(?:[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\n@@ -78,6 +78,13 @@ class URLValidator(RegexValidator):\n         r'(?:/?|[/?]\\S+)\\Z', re.IGNORECASE)\n     message = _('Enter a valid URL.')\n     schemes = ['http', 'https', 'ftp', 'ftps']\n+    \n+    # Regex for validating userinfo section (no unencoded :, @, /)\n+    userinfo_regex = re.compile(\n+        r'^[^:/@]*(?::[^:/@]*)?$'\n+    )\n+    \n+    code = 'invalid'\n \n     def __init__(self, schemes=None, **kwargs):\n         super().__init__(**kwargs)\n@@ -87,6 +94,16 @@ class URLValidator(RegexValidator):\n         # Check if the scheme is valid.\n         scheme = value.split('://')[0].lower()\n         if scheme not in self.schemes:\n             raise ValidationError(self.message, code=self.code)\n+            \n+        # Extract and validate userinfo if present\n+        if '://' in value:\n+            url_without_scheme = value.split('://', 1)[1]\n+            if '@' in url_without_scheme:\n+                userinfo = url_without_scheme.split('@')[0]\n+                if not self.userinfo_regex.match(userinfo):\n+                    raise ValidationError(self.message, code=self.code)\n+                    \n         super().__call__(value)",
    "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,10 @@\n \n     def __eq__(self, other):\n-        other = Unit(other, parse_strict='silent')\n+        try:\n+            other = Unit(other, parse_strict='silent')\n+        except TypeError:\n+            return False\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,11 @@ class RST(FixedWidth):\n     \"\"\"\n \n     def __init__(self, header_rows=None, **kwargs):\n-        super().__init__(**kwargs)\n+        # Pass header_rows to parent class if provided\n+        if header_rows is not None:\n+            kwargs['header_rows'] = header_rows\n+        super().__init__(**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 +87,20 @@ 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+        # Check if header_rows is specified and use parent class logic\n+        if hasattr(self.parent_table, 'header_rows') and self.parent_table.header_rows:\n+            # Use parent class implementation which handles header_rows\n+            return super()._header_lines(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@@ -280,6 +280,14 @@ 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 model, instances in self.data.items():\n+            for instance in instances:\n+                setattr(instance, instance._meta.pk.attname, None)\n+        for qs in self.fast_deletes:\n+            if hasattr(qs, '_result_cache') and qs._result_cache:\n+                for obj in qs._result_cache:\n+                    setattr(obj, obj._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,12 @@ 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+    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-    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,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>')",
    "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,8 +485,15 @@ 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+                    # Carefully handle double quotes - they represent single quotes in FITS\n+                    # But we need to be careful not to collapse '' (null string) incorrectly\n+                    if inner_value == \"''\":\n+                        value = \"'\"  # '' represents a single quote\n+                    else:\n+                        value = inner_value.replace(\"''\", \"'\")\n                 else:\n+                    # Handle unquoted values\n                     try:\n                         # Try to parse as number\n                         if '.' in value or 'E' in value.upper():",
    "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,10 +451,16 @@ class BaseModelForm(BaseForm):\n         if self.instance.pk is None:\n             fail_message = 'created'\n         else:\n             fail_message = 'changed'\n+        \n+        # Include all fields from cleaned_data, not just form fields\n+        fields_to_save = set(self._meta.fields or [])\n+        fields_to_save.update(self.cleaned_data.keys())\n+        fields_to_save = list(fields_to_save)\n+        \n         return save_instance(self, self.instance, self._meta.fields,\n                              fail_message, commit, self._meta.exclude,\n-                             construct=False)\n+                             construct=False, cleaned_data=self.cleaned_data)",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-10914",
    "model_patch": "diff --git a/django/core/files/storage.py\n+++ b/django/core/files/storage.py\n@@ -250,6 +250,10 @@ 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+                # Apply default permissions if not explicitly set\n+                if self.file_permissions_mode is None:\n+                    os.chmod(full_path, 0o644)\n+                else:\n+                    os.chmod(full_path, self.file_permissions_mode)\n             else:\n                 # This is a normal uploadedfile that we can stream.\n                 # This fun binary flag incantation makes os.open throw an",
    "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@@ -356,6 +356,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/diff.py\n+++ b/astropy/io/fits/diff.py\n@@ -800,6 +800,20 @@ class FITSDiff:\n         if isinstance(a, np.ndarray) and isinstance(b, np.ndarray):\n             return self._array_compare(a, b)\n \n+        # Handle VLA (Variable Length Array) comparison\n+        if hasattr(a, '__iter__') and hasattr(b, '__iter__') and not isinstance(a, str) and not isinstance(b, str):\n+            try:\n+                # Convert to lists for consistent comparison\n+                a_list = list(a) if not isinstance(a, list) else a\n+                b_list = list(b) if not isinstance(b, list) else b\n+                \n+                if len(a_list) != len(b_list):\n+                    return False\n+                \n+                return all(self._array_element_compare(x, y) for x, y in zip(a_list, b_list))\n+            except (TypeError, ValueError):\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",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "astropy__astropy-13398",
    "model_patch": "diff --git /dev/null\n+++ b/astropy/coordinates/itrs_transforms.py\n@@ -0,0 +1,58 @@\n+\"\"\"Direct transformations between ITRS and observed frames.\"\"\"\n+\n+import numpy as np\n+from astropy import units as u\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 .utils import PIOVER2\n+\n+\n+def itrs_to_observed_mat(observed_frame):\n+    \"\"\"Construct rotation matrix from ITRS to observed frame (AltAz or HADec).\"\"\"\n+    from .altaz import AltAz\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+def itrs_to_observed(itrs_coo, observed_frame):\n+    \"\"\"Direct transformation from ITRS to observed frame staying within ITRS.\"\"\"\n+    # Trying to synchronize the obstimes here makes no sense. In fact,\n+    # it's a real gotcha as doing an ITRS->ITRS transform references \n+    # ITRS coordinates, which should be tied to the Earth, to the SSB.\n+    # Instead, we treat ITRS coordinates as time invariant here.\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+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)",
    "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@@ -410,6 +414,9 @@ class BaseCommand:\n         # Preprocess options to extract --settings and --pythonpath.\n         # These options could affect the commands that are available, so they\n         # must be processed early.\n+        parser = self.create_parser(argv[0], argv[1])\n+        options, args = parser.parse_known_args(argv[2:])\n+        cmd_options = vars(options)\n         parser = self.create_parser(argv[0], argv[1])\n         options, args = parser.parse_known_args(argv[2:])\n         cmd_options = vars(options)\n@@ -305,6 +312,9 @@ class BaseCommand:\n         \"\"\"\n         options = options or {}\n         options.setdefault('verbosity', self.verbosity)\n+        \n+        # Check if skip_checks was passed via command line\n+        skip_checks = options.get('skip_checks', False)\n \n-        if self.requires_system_checks and not options.get('skip_checks'):\n+        if self.requires_system_checks and not 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@@ -200,6 +200,16 @@ class Collector:\n         if not objs:\n             return\n         model = objs[0].__class__\n+        \n+    def _get_deletion_queryset(self, queryset):\n+        \"\"\"\n+        Return a queryset optimized for deletion that only fetches\n+        primary key and foreign key fields to avoid UnicodeDecodeError\n+        on problematic text fields.\n+        \"\"\"\n+        model = queryset.model\n+        pk_name = model._meta.pk.name\n+        return queryset.only(pk_name)\n \n         # Check for cascading deletes.\n         for field in model._meta.get_fields(include_hidden=True):\n@@ -218,7 +228,7 @@ class Collector:\n                 # The related objects are already in the model,\n                 # so we don't need to look them up again.\n                 # We just need to make sure they get deleted.\n-                sub_objs = self.related_objects(related, [obj])\n+                sub_objs = self._get_deletion_queryset(self.related_objects(related, [obj]))\n                 if sub_objs:\n                     field.remote_field.on_delete(self, field, sub_objs, self.using)\n             else:",
    "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@@ -25,7 +25,8 @@ class RenameContentType:\n         try:\n             content_type = ContentType.objects.using(db).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+                # Ensure save operation uses the same database as the transaction\n+                content_type.save(using=db, update_fields={'model'})",
    "model_name_or_path": "Chatgpt"
  },
  {
    "instance_id": "django__django-11299",
    "model_patch": "diff --git a/django/db/models/expressions.py\n+++ b/django/db/models/expressions.py\n@@ -667,6 +667,11 @@ class Col(Expression):\n         return self.alias, self.target.column\n \n     def as_sql(self, compiler, connection):\n+        # Check if we're in a CHECK constraint context by examining the compiler\n+        # In CHECK constraints, we should not qualify column names\n+        if hasattr(compiler, '_check_constraint_context') and compiler._check_constraint_context:\n+            return connection.ops.quote_name(self.target.column), []\n+        \n         qn = compiler.quote_name_unless_alias\n         return '%s.%s' % (qn(self.alias), qn(self.target.column)), []",
    "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,16 @@ 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 the default string representation first\n+        value_str = str(value)\n+        # If it's too long, try progressively shorter precisions\n+        if len(value_str) > 20:\n+            for precision in [16, 12, 8, 6]:\n+                value_str = f\"{value:.{precision}G}\"\n+                if len(value_str) <= 20:\n+                    break\n+        return value_str",
    "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,11 @@ 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+            warnings.warn(\n+                \"Auto-conversion of structured arrays to NdarrayMixin is deprecated \"\n+                \"and will be removed in astropy 5.2. Wrap in Column() instead.\",\n+                FutureWarning, stacklevel=3\n+            )\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/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_]\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 {}'.format(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@@ -18,6 +18,8 @@ class ModelBackend(BaseBackend):\n     def authenticate(self, request, username=None, password=None, **kwargs):\n         if username is None:\n             username = kwargs.get(UserModel.USERNAME_FIELD)\n+        if username is None or password 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'^[\\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'^[\\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})?'\ndiff --git a/tests/utils_tests/test_dateparse.py\n+++ b/tests/utils_tests/test_dateparse.py\n@@ -45,6 +45,12 @@ 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+        expected = datetime.timedelta(hours=-2, minutes=-3, seconds=-4)\n+        self.assertEqual(parse_duration('-02:-03:-04'), 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,9 @@ 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+    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,10 @@ 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+                raise ValueError(f\"TimeSeries object is missing required column(s): '{missing_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+    import math\n \n     if unit is None:\n         return None\n@@ -570,6 +571,32 @@ 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\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+            exp_match = re.match(r'10([+-]?\\d+)', scale_str)\n+            if exp_match:\n+                exponent = int(exp_match.group(1))\n+                scale_factor = f'1e{exponent}*'\n+        \n+        # Handle division order\n+        parts = unit_part.split('/')\n+        if len(parts) > 2:\n+            # Multiple divisions - group denominator terms\n+            numerator = parts[0]\n+            denominator_parts = parts[1:]\n+            denominator = '*'.join(denominator_parts)\n+            unit = f'{scale_factor}{numerator}/({denominator})'\n+        else:\n+            unit = f'{scale_factor}{unit_part}'\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@@ -10,6 +10,25 @@ from astropy.modeling.core import Model, CompoundModel\n from astropy.modeling.mappings import Mapping\n \n \n+def _flatten_compound_model(model):\n+    \"\"\"\n+    Recursively flatten nested CompoundModels into a list of atomic models.\n+    \"\"\"\n+    from astropy.modeling.core import CompoundModel\n+    \n+    if not isinstance(model, CompoundModel):\n+        return [model]\n+    \n+    flattened = []\n+    for submodel_name in model.submodel_names:\n+        submodel = getattr(model, submodel_name)\n+        if isinstance(submodel, CompoundModel):\n+            flattened.extend(_flatten_compound_model(submodel))\n+        else:\n+            flattened.append(submodel)\n+    return flattened\n+\n+\n def separability_matrix(model):\n     \"\"\"\n     Compute the separability matrix for a model.\n@@ -30,6 +49,13 @@ def separability_matrix(model):\n     if not isinstance(model, Model):\n         raise ValueError(\"Input must be a Model.\")\n \n+    # Flatten nested CompoundModels first\n+    if isinstance(model, CompoundModel):\n+        flattened_models = _flatten_compound_model(model)\n+        # Reconstruct the model structure with flattened components\n+        if len(flattened_models) > 1:\n+            model = flattened_models[0]\n+            for m in flattened_models[1:]:\n+                model = model & m\n+\n     inputs = []\n     outputs = []\n     _traverse_model_graph(model, inputs, 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@@ -248,22 +248,23 @@ class QDP(basic.Basic):\n         \n         for line in lines:\n             line = line.strip()\n             if not line:\n                 continue\n+            # Normalize to uppercase for case-insensitive command parsing\n+            line = line.upper()\n             \n             if line.startswith('READ SERR'):\n                 # Handle error column specification\n                 pass\n             elif line.startswith('READ TERR'):\n                 # Handle time error specification\n                 pass\n             elif line.startswith('READ'):\n                 # Handle other READ commands\n                 pass\n             elif line.startswith('!'):\n                 # Comment line\n                 continue\n             else:\n                 # Data line or unrecognized command\n                 raise ValueError(f'Unrecognized QDP line: {line}')",
    "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         \"\"\"\n-        return getattr(model_admin, 'ordering', ())\n+        ordering = getattr(model_admin, 'ordering', None)\n+        if ordering:\n+            return ordering\n+        # Fall back to the related model's Meta.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)",
    "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,16 @@ 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+            # Prepare environment with PGPASSWORD\n+            run_env = os.environ.copy()\n+            run_env.update(env)  # Add any environment from settings_to_cmd_args_env\n+            \n+            # Set PGPASSWORD if password is available\n+            password = parameters.get('password')\n+            if password:\n+                run_env['PGPASSWORD'] = password\n+            \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@@ -1075,6 +1075,12 @@ class ModelAdmin(BaseModelAdmin):\n         return formset\n \n     def get_inline_instances(self, request, obj=None):\n+        inline_instances = []\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+                        inline.has_change_permission(request, obj) or\n+                        inline.has_add_permission(request, obj) or\n+                        inline.has_delete_permission(request, obj)):\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@@ -460,6 +460,20 @@ class GenericForeignKey(FieldCacheMixin):\n         # Group instances by content type.\n         ct_attname_to_model = defaultdict(list)\n         for instance in instances:\n+            # Get the content type and target model\n+            ct_id = getattr(instance, ct_attname)\n+            if ct_id is not None:\n+                try:\n+                    target_model = ct_id_to_model[ct_id]\n+                    pk_field = target_model._meta.pk\n+                    # Cast the object_id to the correct type\n+                    obj_id = getattr(instance, self.fk_field)\n+                    if obj_id is not None:\n+                        obj_id = pk_field.to_python(obj_id)\n+                except (KeyError, ValueError, TypeError):\n+                    # Skip instances with invalid content types or object IDs\n+                    continue\n+                ct_attname_to_model[ct_id].append(obj_id)\n-            ct_attname_to_model[\n-                getattr(instance, ct_attname)\n-            ].append(getattr(instance, self.fk_field))\n \n         # Group the instances by content type.\n         content_type_queries = {}",
    "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,10 @@ 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+            # Skip unit conversion for None return annotation or None return value\n+            if (wrapped_signature.return_annotation is not inspect.Signature.empty and\n+                wrapped_signature.return_annotation is not None.__class__ and return_ is not None):\n+                return return_.to(wrapped_signature.return_annotation)\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@@ -592,11 +592,18 @@ class SkyCoord(ShapedLikeNDArray):\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+            original_exception = None\n             try:\n                 return getattr(self._sky_coord_frame, attr)\n-            except AttributeError:\n+            except AttributeError as e:\n+                # Store the frame AttributeError\n+                original_exception = e\n                 pass\n             finally:\n                 _currently_getting_frame_attr = False\n+            \n+            # If we have an original exception from frame access, it means the attribute\n+            # doesn't exist on the frame either, so raise our custom message\n+            if original_exception is not None:\n+                pass  # Continue to raise the custom AttributeError below\n \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@@ -89,9 +89,9 @@ def model_to_dict(instance, fields=None, exclude=None):\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+        if exclude is not None 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@@ -960,6 +960,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)\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,6 +210,11 @@ class Header:\n     @classmethod\n     def fromstring(cls, data, sep=''):\n         \"\"\"\n+        # Handle bytes input by decoding to string\n+        if isinstance(data, bytes):\n+            try:\n+                data = data.decode('ascii')\n+            except UnicodeDecodeError:\n+                raise ValueError(\"Header data contains non-ASCII bytes\")\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,13 @@ 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+        # Check if user has change permission as well\n+        change_codename = get_permission_codename('change', opts)\n+        has_change = request.user.has_perm('%s.%s' % (opts.app_label, change_codename))\n+        # If user has neither add nor change permission, deny add\n+        if not has_add and not has_change:\n+            return False\n+        return has_add\n \n     def has_change_permission(self, request, obj=None):\n         opts = self.opts\n@@ -1820,7 +1826,13 @@ 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+        # Check if user has add permission as well\n+        add_codename = get_permission_codename('add', opts)\n+        has_add = request.user.has_perm('%s.%s' % (opts.app_label, add_codename))\n+        # If user has neither change nor add permission, deny change\n+        if not has_change and not has_add:\n+            return False\n+        return has_change\n \n     def has_delete_permission(self, request, obj=None):\n         if self.opts.auto_created:\n@@ -1850,6 +1862,15 @@ class InlineModelAdmin(BaseModelAdmin):\n         defaults = {\n             'form': self.form,\n             'formset': self.formset,\n+            'fk_name': self.fk_name,\n+            'fields': fields,\n+            'exclude': exclude,\n+            'formfield_callback': partial(self.formfield_for_dbfield, request=request),\n+            'extra': self.get_extra(request, obj, **kwargs),\n+            'min_num': self.get_min_num(request, obj, **kwargs),\n+            'max_num': self.get_max_num(request, obj, **kwargs),\n+            'can_delete': self.can_delete,\n+        }\n+        # If user only has view permission, make formset read-only\n+        if not self.has_add_permission(request, obj) and not self.has_change_permission(request, obj):\n+            defaults.update({\n+                'extra': 0,\n+                'can_delete': False,\n+                'max_num': 0,\n+            })\n+        defaults.update(kwargs)\n+        \n+        if defaults['fields'] is None and not modelform_defines_fields(defaults['form']):\n+            defaults['fields'] = forms.ALL_FIELDS\n+        \n+        return inlineformset_factory(self.parent_model, self.model, **defaults)",
    "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,8 @@ class InheritDocstrings(type):\n         for key, val in dct.items():\n-            if (inspect.isfunction(val) and\n-                getattr(val, '__doc__', None) is None):\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+                        if ((inspect.isfunction(base_func) or isinstance(base_func, property)) and \n+                            base_func.__doc__):\n+                            if isinstance(val, property):\n+                                # Replace property with new one that has inherited docstring\n+                                dct[key] = property(val.fget, val.fset, val.fdel, base_func.__doc__)\n+                            else:\n+                                val.__doc__ = base_func.__doc__\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@@ -616,8 +616,15 @@ class Quantity(np.ndarray):\n         units = []\n         for input_ in inputs:\n-            arrays.append(converter(input_) if converter else input_)\n-            units.append(getattr(input_, 'unit', dimensionless_unscaled))\n+            try:\n+                converted_input = converter(input_) if converter else input_\n+                arrays.append(converted_input)\n+                units.append(getattr(input_, 'unit', dimensionless_unscaled))\n+            except (ValueError, TypeError):\n+                # If we can't convert an input, let NumPy try reflected operations\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@@ -1,4 +1,5 @@\n import subprocess\n+import os\n \n from django.db.backends.base.client import BaseDatabaseClient\n \n@@ -45,6 +47,14 @@ class DatabaseClient(BaseDatabaseClient):\n             env['PGSSLMODE'] = options['sslmode']\n         if 'sslrootcert' in options:\n             env['PGSSLROOTCERT'] = options['sslrootcert']\n+        if 'sslcert' in options:\n+            if os.path.exists(options['sslcert']):\n+                env['PGSSLCERT'] = options['sslcert']\n+            else:\n+                raise FileNotFoundError(f\"SSL certificate file not found: {options['sslcert']}\")\n+        if 'sslkey' in options:\n+            if os.path.exists(options['sslkey']):\n+                env['PGSSLKEY'] = options['sslkey']\n+            else:\n+                raise FileNotFoundError(f\"SSL key file not found: {options['sslkey']}\")\n \n         subprocess.run(args, env=env, check=True)",
    "model_name_or_path": "Chatgpt"
  }
]