{
  "original_problem": {
    "instance_id": "django__django-14752",
    "repo": "django/django",
    "created_at": "2021-08-07T16:34:32Z",
    "problem_statement": "Refactor AutocompleteJsonView to support extra fields in autocomplete response\nDescription\n\t \n\t\t(last modified by mrts)\n\t \nAdding data attributes to items in ordinary non-autocomplete foreign key fields that use forms.widgets.Select-based widgets is relatively easy. This enables powerful and dynamic admin site customizations where fields from related models are updated immediately when users change the selected item.\nHowever, adding new attributes to autocomplete field results currently requires extending contrib.admin.views.autocomplete.AutocompleteJsonView and fully overriding the AutocompleteJsonView.get() method. Here's an example:\nclass MyModelAdmin(admin.ModelAdmin):\n\tdef get_urls(self):\n\t\treturn [\n\t\t\tpath('autocomplete/', CustomAutocompleteJsonView.as_view(admin_site=self.admin_site))\n\t\t\tif url.pattern.match('autocomplete/')\n\t\t\telse url for url in super().get_urls()\n\t\t]\nclass CustomAutocompleteJsonView(AutocompleteJsonView):\n\tdef get(self, request, *args, **kwargs):\n\t\tself.term, self.model_admin, self.source_field, to_field_name = self.process_request(request)\n\t\tif not self.has_perm(request):\n\t\t\traise PermissionDenied\n\t\tself.object_list = self.get_queryset()\n\t\tcontext = self.get_context_data()\n\t\treturn JsonResponse({\n\t\t\t'results': [\n\t\t\t\t{'id': str(getattr(obj, to_field_name)), 'text': str(obj), 'notes': obj.notes} # <-- customization here\n\t\t\t\tfor obj in context['object_list']\n\t\t\t],\n\t\t\t'pagination': {'more': context['page_obj'].has_next()},\n\t\t})\nThe problem with this is that as AutocompleteJsonView.get() keeps evolving, there's quite a lot of maintenance overhead required to catch up.\nThe solutions is simple, side-effect- and risk-free: adding a result customization extension point to get() by moving the lines that construct the results inside JsonResponse constructor to a separate method. So instead of\n\t\treturn JsonResponse({\n\t\t\t'results': [\n\t\t\t\t{'id': str(getattr(obj, to_field_name)), 'text': str(obj)}\n\t\t\t\tfor obj in context['object_list']\n\t\t\t],\n\t\t\t'pagination': {'more': context['page_obj'].has_next()},\n\t\t})\nthere would be\n\t\treturn JsonResponse({\n\t\t\t'results': [\n\t\t\t\tself.serialize_result(obj, to_field_name) for obj in context['object_list']\n\t\t\t],\n\t\t\t'pagination': {'more': context['page_obj'].has_next()},\n\t\t})\nwhere serialize_result() contains the original object to dictionary conversion code that would be now easy to override:\ndef serialize_result(self, obj, to_field_name):\n\treturn {'id': str(getattr(obj, to_field_name)), 'text': str(obj)}\nThe example CustomAutocompleteJsonView from above would now become succinct and maintainable:\nclass CustomAutocompleteJsonView(AutocompleteJsonView):\n\tdef serialize_result(self, obj, to_field_name):\n\t\treturn super.serialize_result(obj, to_field_name) | {'notes': obj.notes}\nWhat do you think, is this acceptable? I'm more than happy to provide the patch.\n",
    "patch": "diff --git a/django/contrib/admin/views/autocomplete.py b/django/contrib/admin/views/autocomplete.py\n--- a/django/contrib/admin/views/autocomplete.py\n+++ b/django/contrib/admin/views/autocomplete.py\n@@ -11,7 +11,8 @@ class AutocompleteJsonView(BaseListView):\n \n     def get(self, request, *args, **kwargs):\n         \"\"\"\n-        Return a JsonResponse with search results of the form:\n+        Return a JsonResponse with search results as defined in\n+        serialize_result(), by default:\n         {\n             results: [{id: \"123\" text: \"foo\"}],\n             pagination: {more: true}\n@@ -26,12 +27,19 @@ def get(self, request, *args, **kwargs):\n         context = self.get_context_data()\n         return JsonResponse({\n             'results': [\n-                {'id': str(getattr(obj, to_field_name)), 'text': str(obj)}\n+                self.serialize_result(obj, to_field_name)\n                 for obj in context['object_list']\n             ],\n             'pagination': {'more': context['page_obj'].has_next()},\n         })\n \n+    def serialize_result(self, obj, to_field_name):\n+        \"\"\"\n+        Convert the provided model object to a dictionary that is added to the\n+        results list.\n+        \"\"\"\n+        return {'id': str(getattr(obj, to_field_name)), 'text': str(obj)}\n+\n     def get_paginator(self, *args, **kwargs):\n         \"\"\"Use the ModelAdmin's paginator.\"\"\"\n         return self.model_admin.get_paginator(self.request, *args, **kwargs)\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_27935",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about index naming constraints, which is unrelated to method refactoring or extension points."
      },
      {
        "idx": 2,
        "id": "similar_32754",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue deals with URL construction errors, not method refactoring or extension points."
      },
      {
        "idx": 3,
        "id": "similar_27068",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue focuses on form data handling inconsistencies, not on method refactoring or extension points."
      },
      {
        "idx": 4,
        "id": "similar_29413",
        "decision": "Useful",
        "confidence": "Medium",
        "reason": "Both issues involve restructuring code to improve efficiency and maintainability by separating concerns."
      },
      {
        "idx": 5,
        "id": "similar_28058",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about behavioral changes in form field evaluation, unrelated to method refactoring or extension points."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "BrinIndex crashes if name  > 30 characters",
        "issue_body": "BrinIndex.suffix ( django.contrib.postgres.indexes) longer 3 char, but Index.set_name_with_model method allowed 3 char in suffix\nAssertionError: Index too long for multiple database support. Is self.suffix longer than 3 characters?",
        "issue_id": 27935,
        "pr_number": 8213,
        "pr_title": "Refs #27935 -- Fixed BrinIndex.max_name_length if a project's default database isn't PostgreSQL.",
        "pr_body": "",
        "issue_closed_at": "2017-03-20T10:30:05",
        "base_commit": "6cb0a3ac2836c044987f7a0cca0d1e99d52e002e"
      },
      "summary": "### Summary:\n\nThis issue pertains to an error in the Django framework, specifically within the PostgreSQL indexing system. The problem arises when creating a BrinIndex, a type of PostgreSQL index, with a suffix name exceeding three characters. The current implementation of the `Index.set_name_with_model` method restricts suffixes to three characters, leading to an assertion error when this limit is exceeded. This behavior triggers a crash, highlighting a discrepancy between allowed suffix lengths across different components. The key symptom observed is an `AssertionError` stating that the index name is too long for supporting multiple databases. The problem affects the BrinIndex component in Django's PostgreSQL module and could potentially impact applications relying on longer index suffixes, leading to failures during database migrations or index creations. The severity of this issue depends on the reliance on longer index names in multi-database environments. The technical insight here is the misalignment of suffix length constraints between different methods managing index names.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: BrinIndex crashes if name  > 30 characters\n\nBody:\nBrinIndex.suffix ( django.contrib.postgres.indexes) longer 3 char, but Index.set_name_with_model method allowed 3 char in suffix\nAssertionError: Index too long for multiple database support. Is self.suffix longer than 3 characters?\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/contrib/postgres/indexes.py\n  line: line 1\n  function: BrinIndex.get_sql_create_template_values\n"
    },
    {
      "similar_issue": {
        "issue_title": "catch_all_view() does not support FORCE_SCRIPT_NAME.",
        "issue_body": "catch_all_view\nreturns redirect to\n'%s/' % request.path_info\n(script name cut off there) instead of\n'%s/' % request.path\n(with the script name)\nPatch -\n​\nhttps://github.com/django/django/pull/14404",
        "issue_id": 32754,
        "pr_number": 14404,
        "pr_title": " Fixed #32754 -- Made AdminSite.catch_all_view() respect SCRIPT_NAME.",
        "pr_body": "",
        "issue_closed_at": "2021-05-18T02:58:51",
        "base_commit": "de32fe83a2e4a20887972c69a0693b94eb25a88b"
      },
      "summary": "### Summary:\nThis issue is related to a bug in the Django web framework, specifically in the `catch_all_view()` function, which fails to correctly support the configuration directive `FORCE_SCRIPT_NAME`. This directive is used to prefix URLs with a specific script path, which is essential for certain deployment scenarios, such as when the application is hosted under a sub-path within a domain.\n\n1. **Problem Description:**\n   In general terms, the problem arises when the `catch_all_view()` function generates a redirect URL. It incorrectly omits the script name from the redirect path, which should be included for proper URL resolution in environments where `FORCE_SCRIPT_NAME` is used.\n\n2. **Key Symptoms and Behaviors Observed:**\n   The primary symptom reported is the incorrect construction of redirect URLs. Instead of using the complete request path that includes the script name (`%s/` % request.path), the function only uses the path information without the script name (`%s/` % request.path_info). This leads to broken links or incorrect URL redirections.\n\n3. **Affected Components or Systems:**\n   The issue specifically affects the `catch_all_view()` function within the Django framework. This may impact any Django application that relies on this function and is deployed in an environment where `FORCE_SCRIPT_NAME` is configured.\n\n4. **Potential Impact or Severity:**\n   The severity of this issue depends on the deployment context. For applications that do not use `FORCE_SCRIPT_NAME`, the issue may go unnoticed. However, for applications deployed on sub-paths where the correct script name in URLs is crucial, this bug can lead to significant disruptions, including broken navigation and inaccessible resources.\n\n5. **Relevant Technical Details:**\n   The issue stems from the misalignment between the constructed URL path and the expected URL path in environments utilizing `FORCE_SCRIPT_NAME`. The patch provided in the linked pull request likely addresses this by ensuring that the script name is included in the redirect URL, aligning it with the complete request path.\n\nChanges were made to the `django/contrib/admin/sites.py` file, particularly in the `AdminSite.autocomplete_view` function, to correct the URL construction behavior.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: catch_all_view() does not support FORCE_SCRIPT_NAME.\n\nBody:\ncatch_all_view\nreturns redirect to\n'%s/' % request.path_info\n(script name cut off there) instead of\n'%s/' % request.path\n(with the script name)\nPatch -\n​\nhttps://github.com/django/django/pull/14404\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/contrib/admin/sites.py\n  function: AdminSite.autocomplete_view\n"
    },
    {
      "similar_issue": {
        "issue_title": "Acquire form's initial data more consistently",
        "issue_body": "In\nBoundField\n, sometimes initial data\n​\nhandles callables\n. While other times,\n​\nit doesn't\n. This can lead to a theoretical bug when the initial data is a callable, but the field is disabled.\nOther times, the initial callable is handled, but microseconds are\n​\nnot chopped\nleading to theoretical false positives that data has changed.\nInitial data should be handled more consistently across all cases.\nMarking as a bug due to the theoretical edge cases that can produce unexpected results. Noticed these inconsistencies while working on\n#27037\n.",
        "issue_id": 27068,
        "pr_number": 7097,
        "pr_title": "Fixed #27068 -- Unified form field initial data retrieval.",
        "pr_body": "https://code.djangoproject.com/ticket/27068\n",
        "issue_closed_at": "2016-08-18T19:51:32",
        "base_commit": "13857b45ca54a519a58361238442af84262c0d23"
      },
      "summary": "### Summary: This issue pertains to inconsistencies in how initial data is managed within form fields, specifically in Django's form handling system. The problem arises due to the inconsistent treatment of initial data when it is a callable, especially when form fields are disabled. Additionally, there are inconsistencies related to handling microseconds in initial data, which can lead to incorrect assessments of whether the data has changed. These inconsistencies could result in theoretical bugs, leading to unexpected behaviors in form processing.\n\n1. Problem description in general terms:\n   - The issue revolves around the inconsistent handling of initial data in form fields, particularly when the initial data is a callable. This inconsistency can create potential bugs and unexpected results during form processing.\n\n2. Key symptoms and behaviors observed:\n   - Callables used as initial data are sometimes processed differently, depending on whether the field is enabled or disabled.\n   - Microseconds in initial data are not consistently managed, potentially causing false positives in data change detection.\n\n3. Affected components or systems:\n   - The problem affects the Django form handling system, specifically the BoundField and BaseForm functions responsible for handling form data and changes.\n\n4. Potential impact or severity:\n   - The inconsistencies could lead to theoretical edge cases where forms behave unexpectedly. This is marked as a bug due to the potential for unexpected results, which can affect user interactions with forms and data integrity.\n\n5. Any relevant technical details abstracted for broader understanding:\n   - The issue was noticed during work on a related task (#27037).\n   - The fix involves modifications to several key functions within Django's form handling codebase, including BoundField.value, BoundField.id_for_label, BaseForm._clean_fields, BaseForm.changed_data, and BaseForm.visible_fields, to ensure more consistent initial data handling.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Acquire form's initial data more consistently\n\nBody:\nIn\nBoundField\n, sometimes initial data\n​\nhandles callables\n. While other times,\n​\nit doesn't\n. This can lead to a theoretical bug when the initial data is a callable, but the field is disabled.\nOther times, the initial callable is handled, but microseconds are\n​\nnot chopped\nleading to theoretical false positives that data has changed.\nInitial data should be handled more consistently across all cases.\nMarking as a bug due to the theoretical edge cases that can produce unexpected results. Noticed these inconsistencies while working on\n#27037\n.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/forms/boundfield.py\n  function: BoundField.value\n  function: BoundField.id_for_label\n\ndjango/forms/forms.py\n  function: BaseForm._clean_fields\n  function: BaseForm.changed_data\n  function: BaseForm.visible_fields\n"
    },
    {
      "similar_issue": {
        "issue_title": "QuerySet.get_or_create()/update_or_create() shouldn't evaluate lazy defaults unless they are needed",
        "issue_body": "I wish to have ability to write something like this:\nfrom django.utils.functional import lazy\n\nobj, created = model.objects.get_or_create(\n     key=jwt,\n     defaults=lazy(self.get_defaults_for_model, dict)(jwt) \n)\nBut at the moment\n_extract_model_params\nprepare defaults before it's realy needed.\nI think\n_extract_model_params\nshould be separated to\n_prepare_model_lookup\nand\n_prepare_model_params\n.\nSo it will be possible to call\n_prepare_model_params\nwhen\nmodel.DoesNotExist\nor even inside\n_create_object_from_params\n.",
        "issue_id": 29413,
        "pr_number": 9964,
        "pr_title": "Fixed #29413 -- Prevented evaluation of QuerySet.get_or_create()/update_or_create() defaults unless needed.",
        "pr_body": "https://code.djangoproject.com/ticket/29413",
        "issue_closed_at": "2018-07-16T21:09:12",
        "base_commit": "4d48ddd8f93800a80330ec1dee7b7d4afe6ea95a"
      },
      "summary": "### Summary: This issue pertains to the optimization and efficiency of Django's methods `get_or_create()` and `update_or_create()` within the `QuerySet` class. The problem arises from the eager evaluation of default parameters, specifically when using lazy objects, which leads to unnecessary computations when the defaults are not needed. The current implementation involves the preparation of these defaults prematurely, which is inefficient and could potentially impact performance. The issue suggests a restructuring of the code to separate the preparation of model lookup parameters from model parameters. By doing so, defaults would only be evaluated if an object does not exist and needs to be created, thus delaying the evaluation until it is confirmed necessary. This change primarily affects the `QuerySet` methods in `django/db/models/query.py`, and addresses potential inefficiencies in scenarios where lazy evaluation is beneficial. The impact of this improvement could be significant in reducing resource consumption and improving performance for applications that leverage these Django methods with lazy defaults.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: QuerySet.get_or_create()/update_or_create() shouldn't evaluate lazy defaults unless they are needed\n\nBody:\nI wish to have ability to write something like this:\nfrom django.utils.functional import lazy\n\nobj, created = model.objects.get_or_create(\n     key=jwt,\n     defaults=lazy(self.get_defaults_for_model, dict)(jwt) \n)\nBut at the moment\n_extract_model_params\nprepare defaults before it's realy needed.\nI think\n_extract_model_params\nshould be separated to\n_prepare_model_lookup\nand\n_prepare_model_params\n.\nSo it will be possible to call\n_prepare_model_params\nwhen\nmodel.DoesNotExist\nor even inside\n_create_object_from_params\n.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/db/models/query.py\n  function: QuerySet.get_or_create\n  function: QuerySet.update_or_create\n  function: QuerySet._create_object_from_params\n  function: QuerySet._extract_model_params\n"
    },
    {
      "similar_issue": {
        "issue_title": "Empty Select widget (no choices) evaluates to False",
        "issue_body": "Hey guys,\nI'm not sure I catched a bug, but I discovered a change between\nDjango==1.10.6\nand 1.11.\nWhen you initialize a form with a\nSelect\nwidget, and the select widget has no choices (basically an empty tuple), when evaluating the field with\nbool()\n, it will evaluate to\nFalse\n. This causes the\ndjango_widget_tweaks\nmodule not to render a widget when trying to modify it from within a template, as it uses a bool-like evaluation to check if anything is passed to the set_attr.\ncode to reproduce:\nfrom django import forms\n\nclass MyForm(forms.Form):\n    select = forms.ChoiceField(choices=())\n\nx = MyForm()\n\nfor item in x:\n    print(bool(item))\nIt will print\nTrue\nwith\nDjango==1.10.6\n, and\nFalse\nwith\nDjango==1.11\n.\nThe underlying problem is that\nlen()\nfor a Boundfield with no choices will return 0 in the newer version, whereas it returns 1 in the older version.\nthe template code that fails to render with\nDjango==1.11\n{{ widget|set_attr('style:width: 100%') }}\nLike I said, I'm not sure if this change is intended, nevertheless I reported it. Please let me know if this is intended, so I can let the creator of\ndjango_widget_tweaks\nknow.\nCheers",
        "issue_id": 28058,
        "pr_number": 8362,
        "pr_title": "Fixed #28058 -- Restored empty BoundFields evaluating to True.",
        "pr_body": "https://code.djangoproject.com/ticket/28058",
        "issue_closed_at": "2017-04-17T07:49:12",
        "base_commit": "e5dce7b0fbd2965e524ce97114f501319ec2bb6f"
      },
      "summary": "### Summary:\nThis issue pertains to a behavioral change observed in the Django framework between versions 1.10.6 and 1.11, specifically affecting the evaluation of form fields using the Select widget with no choices. The problem arises when a form field, initialized with an empty set of choices, is evaluated using the `bool()` function. In Django 1.10.6, such a field evaluates to `True`, while in Django 1.11, it evaluates to `False`. This change impacts the functionality of third-party modules like `django_widget_tweaks`, which rely on boolean evaluations to conditionally render widgets in templates. \n\nKey symptoms include the failure of template modifications involving the `set_attr` filter when using empty Select widgets in Django 1.11. This behavior is traced back to a change in the `len()` function's behavior for `BoundField` objects with no choices, returning 0 in the newer version as opposed to 1 previously.\n\nThe affected components are Django's form handling system, specifically the `BoundField` class and its associated subwidget functionality. The severity of this issue could be significant for developers relying on certain third-party libraries or custom templates that depend on the previous behavior. \n\nFor broader understanding, this issue highlights the importance of maintaining awareness of changes in default behaviors when upgrading software libraries, as they can have cascading effects on dependent modules and custom implementations. The resolution likely involves adjusting the handling of boolean evaluations within affected libraries or ensuring backward compatibility in Django's form subsystem.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Empty Select widget (no choices) evaluates to False\n\nBody:\nHey guys,\nI'm not sure I catched a bug, but I discovered a change between\nDjango==1.10.6\nand 1.11.\nWhen you initialize a form with a\nSelect\nwidget, and the select widget has no choices (basically an empty tuple), when evaluating the field with\nbool()\n, it will evaluate to\nFalse\n. This causes the\ndjango_widget_tweaks\nmodule not to render a widget when trying to modify it from within a template, as it uses a bool-like evaluation to check if anything is passed to the set_attr.\ncode to reproduce:\nfrom django import forms\n\nclass MyForm(forms.Form):\n    select = forms.ChoiceField(choices=())\n\nx = MyForm()\n\nfor item in x:\n    print(bool(item))\nIt will print\nTrue\nwith\nDjango==1.10.6\n, and\nFalse\nwith\nDjango==1.11\n.\nThe underlying problem is that\nlen()\nfor a Boundfield with no choices will return 0 in the newer version, whereas it returns 1 in the older version.\nthe template code that fails to render with\nDjango==1.11\n{{ widget|set_attr('style:width: 100%') }}\nLike I said, I'm not sure if this change is intended, nevertheless I reported it. Please let me know if this is intended, so I can let the creator of\ndjango_widget_tweaks\nknow.\nCheers\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/forms/boundfield.py\n  function: BoundField.subwidgets\n"
    }
  ]
}