[
  {
    "context": [
      "My JSON looks like this:",
      "{\n  \"pipeline1\": {\n    \"description\": \"Desc 1\",\n    \"last_modified\": \"2023-11-14T09:27:50.235Z\",\n    \"pipeline_metadata\": {\n      \"version\": 1,\n      \"type\": \"logstash_pipeline\"\n    },\n    \"username\": \"user1\",\n    \"pipeline\": \"code\",\n    \"pipeline_settings\": {\n      \"pipeline.batch.delay\": 50,\n      \"pipeline.batch.size\": 125,\n      \"pipeline.workers\": 1,\n      \"queue.checkpoint.writes\": 1024,\n      \"queue.max_bytes\": \"1gb\",\n      \"queue.type\": \"memory\"\n    }\n  }\n}",
      "Expected output:",
      "{\n  \"pipeline\": \"pipeline1\",\n  \"description\": \"Desc 1\"\n  \"last_modified\": \"2023-11-14T09:27:50.235Z\"\n  \"username\": \"user1\"\n  \"pipeline\": \"code\"\n}",
      "Your expected output contains a duplicate key `pipeline`, which jq cannot produce by regular means. But if you accept another name for one of them, e.g. renaming the first one to `parent`, you could get your expected output by decomposing the input with `to_entries`, and then assigning all the target values:",
      "to_entries[]\n| {parent: .key} + (.value | {description, last_modified, username, pipeline})"
    ],
    "utterance": "For each top-level object, output an object containing the key as 'parent' and the properties 'description', 'last_modified', 'username', and 'pipeline' from its value.",
    "expressions": [
      "to_entries[] | {parent: .key} + (.value | {description, last_modified, username, pipeline})"
    ],
    "data": [
      {
        "input": {
          "pipeline1": {
            "description": "Desc 1",
            "last_modified": "2023-11-14T09:27:50.235Z",
            "pipeline_metadata": {
              "version": 1,
              "type": "logstash_pipeline"
            },
            "username": "user1",
            "pipeline": "code",
            "pipeline_settings": {
              "pipeline.batch.delay": 50,
              "pipeline.batch.size": 125,
              "pipeline.workers": 1,
              "queue.checkpoint.writes": 1024,
              "queue.max_bytes": "1gb",
              "queue.type": "memory"
            }
          }
        },
        "output": {
          "parent": "pipeline1",
          "description": "Desc 1",
          "last_modified": "2023-11-14T09:27:50.235Z",
          "username": "user1",
          "pipeline": "code"
        }
      }
    ],
    "identifier": 78042281,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "and what I want is:\n```\n0 2997 32\n1 3191 22\n2 2948 31\n3 1600 28\n```",
      "You seem to be looking for the [`JOIN` operator](https://jqlang.github.io/jq/manual/#sql-style-operators):\n```sh\nfiltre='\n  JOIN(\n    .\"coretemp-isa-0000\"; input.cpus[]; \"Core \\(.cpu)\"; [first.cpu, first.mhz, (\n      last | to_entries[] | select(.key | endswith(\"_input\")).value\n    ) | trunc]\n  ) | join(\" \")\n'\n\njq -r \"$filtre\" <(\u2026sensors\u2026) <(\u2026lscpu\u2026)\n```",
      "```csv\n0 2997 32\n1 3191 22\n2 2948 31\n3 1600 28\n```"
    ],
    "utterance": "Produce rows with each CPU's id, MHz truncated to integer, and corresponding core temperature input, printed as space-separated values per line.",
    "expressions": [
      "JOIN(.\"coretemp-isa-0000\"; input.cpus[]; \"Core \\(.cpu)\"; [first.cpu, first.mhz, (last | to_entries[] | select(.key | endswith(\"_input\")).value) | trunc]) | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "coretemp-isa-0000": {
            "Adapter": "ISA adapter",
            "Package id 0": {
              "temp1_input": 32.0,
              "temp1_max": 80.0,
              "temp1_crit": 99.0,
              "temp1_crit_alarm": 0.0
            },
            "Core 0": {
              "temp2_input": 32.0,
              "temp2_max": 80.0,
              "temp2_crit": 99.0,
              "temp2_crit_alarm": 0.0
            },
            "Core 1": {
              "temp3_input": 22.0,
              "temp3_max": 80.0,
              "temp3_crit": 99.0,
              "temp3_crit_alarm": 0.0
            },
            "Core 2": {
              "temp4_input": 31.0,
              "temp4_max": 80.0,
              "temp4_crit": 99.0,
              "temp4_crit_alarm": 0.0
            },
            "Core 3": {
              "temp5_input": 28.0,
              "temp5_max": 80.0,
              "temp5_crit": 99.0,
              "temp5_crit_alarm": 0.0
            }
          },
          "cpus": [
            {
              "cpu": 0,
              "mhz": 2997.856
            },
            {
              "cpu": 1,
              "mhz": 3191.4871
            },
            {
              "cpu": 2,
              "mhz": 2948.625
            },
            {
              "cpu": 3,
              "mhz": 1600.0
            }
          ]
        },
        "output": [
          "0 2997 32",
          "1 3191 22",
          "2 2948 31",
          "3 1600 28"
        ]
      }
    ],
    "identifier": 78042884,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Input:\n```\n{\n   \"data\": [\n      {\n        \"a\": \"a1\",\n        \"b\": \"b1\",\n        \"c\": \"1\"\n      },\n      {\n        \"a\": \"a2\",\n        \"b\": \"b2\",\n        \"c\": \"2\"\n      }\n    ]\n}\n```",
      "Expected output:\n```\n{\"a\": \"a1\", \"b\": \"b1\"}\n{\"a\": \"a2\", \"b\": \"b2\"}\n```",
      "Expand `.data` only once:\n``` sh\njq -c '.data[] | {a, b}'\n```"
    ],
    "utterance": "Extract each object from the array under the 'data' key, but only include keys 'a' and 'b' in the output.",
    "expressions": [
      ".data[] | {a, b}"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "a": "a1",
              "b": "b1",
              "c": "1"
            },
            {
              "a": "a2",
              "b": "b2",
              "c": "2"
            }
          ]
        },
        "output": [
          {
            "a": "a1",
            "b": "b1"
          },
          {
            "a": "a2",
            "b": "b2"
          }
        ]
      }
    ],
    "identifier": 78045037,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "What I'm trying to get is the \"Line\" number where \"cname\" contains or ends with \"comodoca.com\". For example:\n\n97\n114",
      "data.zone[].record[]\n| select(.cname | tostring | test(\"comodoca[.]com\")).Line"
    ],
    "utterance": "Get the Line numbers of all records whose cname contains or ends with 'comodoca.com'.",
    "expressions": [
      ".data.zone[].record[] | select(.cname | tostring | test(\"comodoca[.]com\")).Line"
    ],
    "data": [
      {
        "input": {
          "data": {
            "zone": [
              {
                "record": [
                  {
                    "Line": 1,
                    "raw": "; cPanel first:11.25.0-CURRENT_46156 (update_time):1708598274 Cpanel::ZoneFile::VERSION:1.3 hostname:server2.something.com latest:110.0.23",
                    "type": ":RAW"
                  },
                  {
                    "Line": 4,
                    "Lines": 1,
                    "class": "IN",
                    "expire": "1209600",
                    "minimum": "86400",
                    "mname": "ns1.something.com",
                    "name": "domain.com.",
                    "refresh": "3600",
                    "retry": "1800",
                    "rname": "noreply.something.com",
                    "serial": "2024022220",
                    "ttl": 86400,
                    "type": "SOA"
                  },
                  {
                    "Line": 6,
                    "address": "195.216.197.40",
                    "class": "IN",
                    "name": "ftp.domain.com.",
                    "ttl": 60,
                    "type": "A"
                  },
                  {
                    "Line": 97,
                    "class": "IN",
                    "cname": "0c960d0901ed2ec4ae18f39c5dcf547e.b3778944564d3daa444a04e58f3b1649.comodoca.com",
                    "name": "_f0ff734bef4f3db24a0dc94fc6b1d21a.fab.domain.com.",
                    "ttl": 60,
                    "type": "CNAME"
                  },
                  {
                    "Line": 114,
                    "class": "IN",
                    "cname": "eaf925d9c7f0fbe3e1abcaa94671918b.814242e76a38aea40755b96ee978a9fc.comodoca.com",
                    "name": "_671f4707fe0a8b2443fc93fe3a7a7a1d.www.software.domain.com.",
                    "ttl": 60,
                    "type": "CNAME"
                  }
                ]
              }
            ]
          },
          "metadata": {
            "command": "dumpzone",
            "reason": "Zone Serialized",
            "result": 1,
            "version": 1
          }
        },
        "output": [
          97,
          114
        ]
      }
    ],
    "identifier": 78048588,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "My input json file:\r\n\r\n    { \"london\": [ \"x\", 0 ] }\r\n    { \"london\": [ \"y\", 97 ] }\r\n    { \"paris\": [ \"x\", 15 ] }\r\n    { \"paris\": [ \"y\", 8 ] }\r\n\r\nI try to group by  key and make the output:\r\n\r\n    { \"london\":  [\"x\", 0], [\"y\", 97] },\r\n    { \"paris\":   [\"x\", 15], [\"y\", 8] }\r\nor:\r\n\r\n    { \"london\": [ {\"x\", 0}, {\"y\", 97} ] },\r\n    { \"paris\":  [ {\"x\", 15}, {\"y\", 8} ] }",
      "jq -n 'reduce (inputs | to_entries)[] as $e ({}; .[$e.key] += [$e.value])'",
      "{\"london\": [[\"x\",0],[\"y\",97]], \"paris\": [[\"x\",15],[\"y\",8]]}",
      "jq -sc 'group_by(keys_unsorted[])[] | {(.[0] | keys_unsorted[]): [.[][]]}'",
      "jq -c '{(.city): .zoo | map([.room.name, .gpu.sum])}'",
      "{\"london\":[[\"x\",0],[\"y\",97]]}\n{\"paris\":[[\"x\",15],[\"y\",8]]}"
    ],
    "utterance": "Group objects by city name as key and collect corresponding arrays as values",
    "expressions": [
      "jq -n 'reduce (inputs | to_entries)[] as $e ({}; .[$e.key] += [$e.value])'",
      "jq -sc 'group_by(keys_unsorted[])[] | {(.[0] | keys_unsorted[]): [.[][]]}'",
      "jq -c '{(.city): .zoo | map([.room.name, .gpu.sum])}'"
    ],
    "data": [
      {
        "input": [
          {
            "london": [
              "x",
              0
            ]
          },
          {
            "london": [
              "y",
              97
            ]
          },
          {
            "paris": [
              "x",
              15
            ]
          },
          {
            "paris": [
              "y",
              8
            ]
          }
        ],
        "output": {
          "london": [
            [
              "x",
              0
            ],
            [
              "y",
              97
            ]
          ],
          "paris": [
            [
              "x",
              15
            ],
            [
              "y",
              8
            ]
          ]
        }
      },
      {
        "input": [
          {
            "city": "london",
            "zoo": [
              {
                "room": {
                  "name": "x"
                },
                "gpu": {
                  "id": "fish",
                  "sum": 0
                }
              },
              {
                "room": {
                  "name": "y"
                },
                "gpu": {
                  "id": "zebra",
                  "sum": 97
                }
              }
            ]
          },
          {
            "city": "paris",
            "zoo": [
              {
                "room": {
                  "name": "x"
                },
                "gpu": {
                  "id": "fish",
                  "sum": 15
                }
              },
              {
                "room": {
                  "name": "y"
                },
                "gpu": {
                  "id": "zebra",
                  "sum": 8
                }
              }
            ]
          }
        ],
        "output": [
          {
            "london": [
              [
                "x",
                0
              ],
              [
                "y",
                97
              ]
            ]
          },
          {
            "paris": [
              [
                "x",
                15
              ],
              [
                "y",
                8
              ]
            ]
          }
        ]
      }
    ],
    "identifier": 78053275,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": true
      },
      "other_task": "The task description is ambiguous: the two examples are structurally different and suggest different groupings and output formats. It is unclear which input/output structure is required, or if both are to be supported.",
      "other_environment": null
    }
  },
  {
    "context": [
      "I have json like this:\r\n\r\n    [\r\n        {\r\n            \"id\": \"1\"\r\n        }, \r\n        {\r\n            \"id\": \"2\"\r\n        }, \r\n        {\r\n            \"id\": \"3\"\r\n        } \r\n    ]",
      "I call some \"sizes.sh\" that give me result:\r\n\r\n    10\r\n    20\r\n    30",
      "How can I update my original json with these results, so it will look:\r\n\r\n    [\r\n        {\r\n            \"id\": \"1\",\r\n            \"size\": 10\r\n        }, \r\n        {\r\n            \"id\": \"2\",\r\n            \"size\": 20\r\n    \r\n        }, \r\n        {\r\n            \"id\": \"3\",\r\n            \"size\": 30\r\n    \r\n        }\r\n    ]",
      "Here is a way:\r\n```\r\n./sizes.sh | jq '[., [{size: inputs}]] | transpose | map(add)' file.json -\r\n```"
    ],
    "utterance": "Append size values 10, 20, and 30 (from command output) as a new field to each object in the input array by index alignment.",
    "expressions": [
      "[., [{size: inputs}]] | transpose | map(add)"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1"
          },
          {
            "id": "2"
          },
          {
            "id": "3"
          }
        ],
        "output": [
          {
            "id": "1",
            "size": 10
          },
          {
            "id": "2",
            "size": 20
          },
          {
            "id": "3",
            "size": 30
          }
        ]
      }
    ],
    "identifier": 78058760,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to change the type to something else, delete the url and checksum key and add a file key in their place with a value.",
      "The final thing should be:",
      "{\n\"arrays\": [\n    {\n      \"name\": \"foo\",\n      \"properties\": [\n        {\n          \"type\": \"Bar\",\n          \"file\": \"filename\"\n        }\n      ]\n    }\n  ]\n}",
      "jq '(.arrays[]| select(.name == \"foo\")).properties |= [{\n    \"type\" : \"bar\",\n    \"file\" : \"filename\"\n}]' test.json"
    ],
    "utterance": "For the object in 'arrays' where name is 'foo', set its 'properties' to an array containing a single object with 'type' equal to 'bar' and 'file' equal to 'filename', removing any 'url' and 'checksum' keys.",
    "expressions": [
      "(.arrays[]| select(.name == \"foo\")).properties |= [{\"type\" : \"bar\", \"file\" : \"filename\"}]"
    ],
    "data": [
      {
        "input": {
          "arrays": [
            {
              "name": "foo",
              "properties": [
                {
                  "type": "app",
                  "url": "https://example.com",
                  "checksum": "d6fd580fe890b826250aa5d5a88bcdb28839cff4d447ba51536cda4ceae89c4e"
                }
              ]
            }
          ]
        },
        "output": {
          "arrays": [
            {
              "name": "foo",
              "properties": [
                {
                  "type": "bar",
                  "file": "filename"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 78060881,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "and I'd like to aggregate (ideally concatenate) the \"char\"-s per font:",
      "Use `add` to concatenate, and `|=` to update:\r\n```sh\r\njq '.[] |= ([.charInfo[].char] | add)'\r\n```",
      "Not efficient, but maybe a bit clearer leveraging `map_values` and `join`:\r\n\r\n```\r\nmap_values(.charInfo|map(.char)|join(\"\")\r\n```"
    ],
    "utterance": "Concatenate all the \"char\" values within each font into a single string, with the font names as keys.",
    "expressions": [
      ".[] |= ([.charInfo[].char] | add)",
      "map_values(.charInfo|map(.char)|join(\"\"))"
    ],
    "data": [
      {
        "input": {
          "font1": {
            "charInfo": [
              {
                "char": "a",
                "other_stuff": 12
              },
              {
                "char": "b",
                "other_stuff": 63
              }
            ]
          },
          "font2": {
            "charInfo": [
              {
                "char": "s",
                "other_stuff": 1
              },
              {
                "char": "x",
                "other_stuff": 4
              }
            ]
          }
        },
        "output": {
          "font1": "ab",
          "font2": "sx"
        }
      }
    ],
    "identifier": 78061337,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I am only looking for 1 result back. It will either have the RMP price if it exists, or it will have the RET price.",
      "My approach would be using `INDEX` to turn the array into an object, and the alternative operator `//` to select a default if the previous returns null:\nmap({\n  sku: .PartNumber,\n  price: (.Prices.Pricing | INDEX(.\"@PriceType\") | .RMP // .RET | .Price.\"#text\")\n})"
    ],
    "utterance": "Select the RMP price for each item if present; if not, select the RET price.",
    "expressions": [
      "map({ sku: .PartNumber, price: (.Prices.Pricing | INDEX(.\"@PriceType\") | .RMP // .RET | .Price.\"#text\") })"
    ],
    "data": [
      {
        "input": [
          {
            "PartNumber": "ABC123",
            "Prices": {
              "Pricing": [
                {
                  "@PriceType": "RET",
                  "Price": {
                    "#text": "230.3800"
                  }
                },
                {
                  "@PriceType": "LST",
                  "Price": {
                    "#text": "230.3800"
                  }
                },
                {
                  "@PriceType": "RMP",
                  "Price": {
                    "#text": "152.0000"
                  }
                }
              ]
            }
          }
        ],
        "output": [
          {
            "sku": "ABC123",
            "price": "152.0000"
          }
        ]
      }
    ],
    "identifier": 78063435,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "More complete response: I want to select an item by the id field, e.g. 174 and get the associated status field",
      "your question should be \"how to extract a property based on another value from a JSON document?\" instead. You don't need a shell loop here, jq is perfectly capable of extracting objects (or values) based on a condition.",
      "jq -r --argjson id 173 '.value[] | select(.configuration.id == $id).status'"
    ],
    "utterance": "Get the status field of the object where configuration.id equals 174.",
    "expressions": [
      "jq -r --argjson id 174 '.value[] | select(.configuration.id == $id).status'"
    ],
    "data": [
      {
        "input": {
          "value": [
            {
              "configuration": {
                "createdBy": {
                  "displayName": "John Smith",
                  "url": "https://url",
                  "_links": {
                    "avatar": {
                      "href": "https://dev.azure.com/thecompany/_apis/GraphProfile/MemberAvatars/aad"
                    }
                  },
                  "id": "0eecda65-30dc-6b28-b497-8411e97df5b6",
                  "uniqueName": "js@thecompany.com",
                  "imageUrl": "https://dev.azure.com/thecompany/_api/_common/",
                  "descriptor": "aad.MGVlY2RhNjUtMzBkYy03YjI4LWI0OTctODQxMWU5N2RmNWI2"
                },
                "createdDate": "2023-01-10T14:52:24.7359941Z",
                "isEnabled": true,
                "isBlocking": true,
                "isDeleted": false,
                "settings": {
                  "minimumApproverCount": 2,
                  "creatorVoteCounts": false,
                  "allowDownvotes": false,
                  "resetOnSourcePush": false,
                  "requireVoteOnLastIteration": true,
                  "resetRejectionsOnSourcePush": false,
                  "blockLastPusherVote": false,
                  "scope": [
                    {
                      "refName": "refs/heads/master",
                      "matchKind": "Exact",
                      "repositoryId": "d416904f-641b-470a-9d"
                    }
                  ]
                },
                "isEnterpriseManaged": false,
                "_links": {
                  "self": {
                    "href": "https://dev.azure.com/thecompany/97f88eba-ecb2-484b-ae7c-c2d43a008cea/_apis/policy/configurations/173"
                  },
                  "policyType": {
                    "href": "https://dev.azure.com/thecompany/97f88eba-ecb2fa4e907d-c16b-4a4c-9dfa-4906e5d171dd"
                  }
                },
                "revision": 16,
                "id": 173,
                "url": "https://dev.azure.com/thecompany/97f88eba-ecb2-484b-ae7c-c2d43a008cea/_apis/policy/configurations/173",
                "type": {
                  "id": "fa4e907d-c16b-171dd",
                  "url": "https://dev.azure.com/thecompany/97f88eba-ecb2-484bc16b-4a4c-9dfa-4906e5d171dd",
                  "displayName": "Minimum number of reviewers"
                }
              },
              "artifactId": "vstfs:///CodeReview/CodeRev2f38956",
              "evaluationId": "0c7b74ad661353ee2",
              "startedDate": "2024-02-22T17:14:01.8987983Z",
              "status": "queued",
              "context": {}
            },
            {
              "configuration": {
                "createdBy": {
                  "displayName": "Jon Snow",
                  "url": "https://s-6ea05e3f7377",
                  "_links": {
                    "avatar": {
                      "href": "https://dev.azure.com/thecompany/_apis/GraphProfile/MemberAvatars/aad.YzZhNGMDVlM2Y3Mzc3"
                    }
                  },
                  "id": "c6a4cf2d-0529-6a3d-88fb-6ea05e3f7377",
                  "uniqueName": "jonsnow@thecompany.com",
                  "imageUrl": "https://dev.azure.com/thecompany/_api/_common/identityIfb-6ea05e3f7377",
                  "descriptor": "aad.YzZhNGNmVhMDVlM2Y3Mzc3"
                },
                "createdDate": "2021-01-28T20:13:48.555187Z",
                "isEnabled": true,
                "isBlocking": true,
                "isDeleted": false,
                "settings": {
                  "requiredReviewerIds": [
                    "b4704bd8fb603d"
                  ],
                  "minimumApproverCount": 1,
                  "creatorVoteCounts": true,
                  "scope": [
                    {
                      "refName": "refs/heads/master",
                      "matchKind": "Exact",
                      "repositoryId": "d4169f-7210d2c5b1ad"
                    }
                  ]
                },
                "isEnterpriseManaged": false,
                "_links": {
                  "self": {
                    "href": "https://dev.azure.com/thecompany/97f88ebay/configurations/174"
                  },
                  "policyType": {
                    "href": "https://dev.azure.com/thecompany/97f88eba-ecb2-8ec8-39368250530e"
                  }
                },
                "revision": 1,
                "id": 174,
                "url": "https://dev.azure.com/thecompany/97f88eba-ecb2-484b-acy/configurations/174",
                "type": {
                  "id": "fd2167ab-b0be68250530e",
                  "url": "https://dev.azure.com/thecompany/97f88eba-ecb2-484b-ae7c-c2d43a008cea/_abe-447a-8ec8-39368250530e",
                  "displayName": "Required reviewers"
                }
              },
              "artifactId": "vstfs:///CodeReview/Ca%2f38956",
              "evaluationId": "8a60f138-10c8-4838-81b4-031763798fdf",
              "startedDate": "2024-02-22T17:12:38.7413814Z",
              "status": "queued"
            }
          ],
          "count": 2
        },
        "output": "queued"
      }
    ],
    "identifier": 78068546,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "This does not work for grabbing the value of \"id\" at a higher level, it returns \"jq: error (at <stdin>:1): Cannot index array with string \"id\"\"",
      "What you probably meant to use is **'.[] | .id'** which is \"map each element of the array to its property 'id'\""
    ],
    "utterance": "Extract the value of the id field from each object in the top-level array.",
    "expressions": [
      ".[] | .id"
    ],
    "data": [
      {
        "input": [
          {
            "id": "xxxxxxxxxxx1111111111",
            "factorType": "webauthn",
            "provider": "FIDO",
            "vendorName": "FIDO",
            "status": "ACTIVE",
            "created": "2024-01-31T19:38:50.000Z",
            "lastVerified": "2024-02-27T13:28:19.000Z",
            "lastUpdated": "2024-01-31T19:38:50.000Z",
            "profile": {
              "credentialId": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
              "appId": null,
              "version": null,
              "authenticatorName": "YubiKey 5",
              "presetPinAvailable": null,
              "fulfillmentProvider": null
            }
          }
        ],
        "output": "xxxxxxxxxxx1111111111"
      }
    ],
    "identifier": 78068982,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to select the objects where the value of the name property starts with \"env.\" (equivalently, where it matches the regex `\"^env\\.\"`)\nand then concatenate the name property value with the value property value like this:\n\nenv.VAR1=\"dogsdrool\"\nenv.VAR2=\"catsrule\"",
      ".[] |select(.name|test(\"^env\"))|\"\\(.name) = \\(.value)\"",
      "echo $data | jq -r '.[]|select(.name|test(\"^env\\\\.\"))|\"\\(.name)=\\(.value|@json)\"' "
    ],
    "utterance": "Output lines in the format name=\"value\" for all objects whose name property starts with env.",
    "expressions": [
      ".[] | select(.name|test(\"^env\\\\.\")) | \"\\(.name)=\\(.value|@json)\"",
      ".[] | select(.name|test(\"^env\\\\.\")) | \"\\(.name) = \\(.value)\""
    ],
    "data": [
      {
        "input": [
          {
            "name": "Genus",
            "value": "canis"
          },
          {
            "name": "env.VAR1",
            "value": "dogsdrool"
          },
          {
            "name": "env.VAR2",
            "value": "catsrule"
          }
        ],
        "output": [
          "env.VAR1=\"dogsdrool\"",
          "env.VAR2=\"catsrule\""
        ]
      }
    ],
    "identifier": 78076363,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "The key `image1`, `image2`, `image3` are the `.content.images.image` value.",
      "The value is the sha256 part of all digests in the Layers as a string list.",
      "You can use `with_entries` to modify each `.key` and `.value`. Or update each subitem `.[] |=` by modifying `key` and the context as value. Then, use `sub` with `\"\"` in the second argument to remove substrings by regex:",
      "yq -oj '.content.images | with_entries(\n  .key = .value.image | .value |= [.layers[].digest | sub(\"^sha256:\", \"\")] \n)'",
      "yq -oj '.content.images | .[] |= (\n  key = .image | [.layers[].digest | sub(\"^sha256:\", \"\")] \n)'"
    ],
    "utterance": "Produce an object mapping each image key ('image1', 'image2', etc.) to a list of all layer digests excluding the 'sha256:' prefix, using the image names from '.content.images[].image' and the digest values from '.content.images[].layers[].digest'.",
    "expressions": [
      ".content.images | with_entries(.key = .value.image | .value |= [.layers[].digest | sub(\"^sha256:\", \"\")])",
      ".content.images | to_entries | map({key: .value.image, value: [.value.layers[].digest | sub(\"^sha256:\", \"\")]}) | from_entries"
    ],
    "data": [
      {
        "input": {
          "content": {
            "images": {
              "sha256:4c8b96d4fffdfae29258d94a22ae4ad1fe36139d47288b8960d9958d1e63a9d0": {
                "annotations": {
                  "kbld.carvel.dev/id": "index.docker.io/dkalinin/k8s-simple-app",
                  "kbld.carvel.dev/origins": "- resolved:\n    tag: latest\n    url: index.docker.io/dkalinin/k8s-simple-app\n"
                },
                "image": "image1",
                "imageType": "Image",
                "layers": [
                  {
                    "digest": "sha256:8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54"
                  }
                ],
                "origin": "index.docker.io/dkalinin/k8s-simple-app@sha256:4c8b96d4fffdfae29258d94a22ae4ad1fe36139d47288b8960d9958d1e63a9d0"
              },
              "sha256:4c8b96d4fffdfae29258d94a22ae4ad1fe36139d47288b8960d9958d1e63a9d1": {
                "annotations": {
                  "kbld.carvel.dev/id": "index.docker.io/dkalinin/k8s-simple-app",
                  "kbld.carvel.dev/origins": "- resolved:\n    tag: latest\n    url: index.docker.io/dkalinin/k8s-simple-app\n"
                },
                "image": "image2",
                "imageType": "Image",
                "layers": [
                  {
                    "digest": "sha256:8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54"
                  },
                  {
                    "digest": "sha256:8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba5h"
                  },
                  {
                    "digest": "sha256:8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba6u"
                  }
                ],
                "origin": "index.docker.io/dkalinin/k8s-simple-app@sha256:4c8b96d4fffdfae29258d94a22ae4ad1fe36139d47288b8960d9958d1e63a9d0"
              },
              "sha256:4c8b96d4fffdfae29258d94a22ae4ad1fe36139d47288b8960d9958d1e63a9d2": {
                "annotations": {
                  "kbld.carvel.dev/id": "index.docker.io/dkalinin/k8s-simple-app",
                  "kbld.carvel.dev/origins": "- resolved:\n    tag: latest\n    url: index.docker.io/dkalinin/k8s-simple-app\n"
                },
                "image": "image3",
                "imageType": "Image",
                "layers": [
                  {
                    "digest": "sha256:8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54"
                  }
                ],
                "origin": "index.docker.io/dkalinin/k8s-simple-app@sha256:4c8b96d4fffdfae29258d94a22ae4ad1fe36139d47288b8960d9958d1e63a9d0"
              }
            }
          }
        },
        "output": {
          "image1": [
            "8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54"
          ],
          "image2": [
            "8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54",
            "8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba5h",
            "8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba6u"
          ],
          "image3": [
            "8ece9ac45f2b7228b2ed95e9f407b4f0dc2ac74f93c62ff1156f24c53042ba54"
          ]
        }
      }
    ],
    "identifier": 78077341,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to convert this json into something like this:\r\n\r\n```\r\n2024-02-28T10:21:51.939Z - info - done\r\n```",
      "echo $msg | jq -r '[.[\"@timestamp\",\"log.level\",\"msg\"]]|join(\" - \")'",
      "echo $msg | jq -r 'values|join(\" - \")'",
      "echo $msg | jq -r 'to_entries|map(.value)|join(\" - \")'",
      "echo $msg | jq -r '[to_entries[].value]|join(\" - \")'"
    ],
    "utterance": "Produce a string with the values of '@timestamp', 'log.level', and 'msg' fields, joined by ' - '",
    "expressions": [
      "[.[\"@timestamp\",\"log.level\",\"msg\"]]|join(\" - \")",
      "values|join(\" - \")",
      "to_entries|map(.value)|join(\" - \")",
      "[to_entries[].value]|join(\" - \")"
    ],
    "data": [
      {
        "input": {
          "@timestamp": "2024-02-28T10:21:51.939Z",
          "log.level": "info",
          "msg": "done"
        },
        "output": "2024-02-28T10:21:51.939Z - info - done"
      }
    ],
    "identifier": 78080371,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "It has worked for me to use `jq -c` to make use of the compact output:",
      "workspaces=$(echo $json_response | jq -c '.value.[]')",
      "However, this doesn't work if there is a space character in the `displayName`:",
      "Use `readarray` to create a bash array of jq's output",
      "readarray -t workspaces < <(jq -c '.value[]' <<< \"$json_response\")"
    ],
    "utterance": "Extract each object in the 'value' array as a compact one-line string, suitable for iteration in a bash array even when properties contain spaces.",
    "expressions": [
      ".value[]",
      "-c .value[]"
    ],
    "data": [
      {
        "input": {
          "value": [
            {
              "displayName": "1"
            },
            {
              "displayName": "2"
            },
            {
              "displayName": "3"
            },
            {
              "displayName": "Has Space"
            }
          ]
        },
        "output": [
          "{\"displayName\":\"1\"}",
          "{\"displayName\":\"2\"}",
          "{\"displayName\":\"3\"}",
          "{\"displayName\":\"Has Space\"}"
        ]
      }
    ],
    "identifier": 78087092,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "But I can't imagine how to select the `message` field by the `createdAt` field. If I select `\"2023-11-29T08:46:30.202778Z\"` I'll get `<bulky message 1>`.",
      "jq --arg time '2023-11-29T08:46:30.202778Z' '\n  .[].data.payload[] | select(.createdAt == $time) | .message\n'"
    ],
    "utterance": "Extract the message field where createdAt equals \"2023-11-29T08:46:30.202778Z\".",
    "expressions": [
      ".[].data.payload[] | select(.createdAt == \"2023-11-29T08:46:30.202778Z\") | .message",
      ".[].data.payload[] | select(.createdAt == $time) | .message"
    ],
    "data": [
      {
        "input": [
          {
            "id": "6a6176c1-b879-8f66-6ccb-2532ec151589",
            "name": "Name",
            "data": {
              "payload": [
                {
                  "initiator": "Manager",
                  "action": "update",
                  "userId": "user",
                  "createdAt": "2023-11-29T08:46:30.202778Z",
                  "message": "<bulky message 1>"
                },
                {
                  "initiator": "clusterManager",
                  "action": "update",
                  "userId": "user",
                  "createdAt": "2023-11-29T08:46:30.202778Z",
                  "message": "<bulky message 2>"
                }
              ]
            }
          }
        ],
        "output": [
          "<bulky message 1>",
          "<bulky message 2>"
        ]
      }
    ],
    "identifier": 78088034,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I need to retrieve an object at a specific index from a massive JSON array. The array contains 2,000,000 objects and the file size is around 5GB.",
      "nth(100000; fromstream(1|truncate_stream(inputs)))",
      "This expression should avoid that overhead and might be faster:\n\n    fromstream(1|truncate_stream( inputs | select(.[0][0] == 100000)))"
    ],
    "utterance": "Retrieve the object at index 100000 from a very large array file without reading the entire array into memory.",
    "expressions": [
      "fromstream(1|truncate_stream(inputs | select(.[0][0] == 100000)))"
    ],
    "data": [
      {
        "input": [
          {
            "Item": {
              "Name": "Darkest Legend",
              "Year": 1992,
              "Genre": [
                "War"
              ],
              "Director": "Sherill Eal Eisenberg",
              "Producer": "Arabella Orth",
              "Screenplay": [
                "Octavia Delmer"
              ],
              "Cast": [
                "Johanna Azar",
                "..."
              ],
              "Runtime": 161,
              "Rate": "9.0",
              "Description": "Robin Northrop Cymbre",
              "Reviews": "Gisela Seumas"
            },
            "Similars": [
              {
                "Name": "Smooth of Edge",
                "Year": 1985,
                "Genre": [
                  "Western"
                ],
                "Director": "Vitoria Eustacia",
                "Producer": "Auguste Jamaal Corry",
                "Screenplay": [
                  "Jaquenette Lance Gibe"
                ],
                "Cast": [
                  "Althea Nicole",
                  "..."
                ],
                "Runtime": 96,
                "Rate": "6.5",
                "Description": "Ashlan Grobe",
                "Reviews": "Annnora Vasquez"
              }
            ]
          },
          "... more objects ..."
        ]
      }
    ],
    "identifier": 78103339,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": true,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I need to split an array from the input JSON into rows and further split the element of the array into columns based on the tab delimiter (\\t)",
      "Input:\n{\n  \"ProcessId\": \"5452\",\n  \"TotalRows\": 226171,\n  \"Rows\": [\n    \"001-CARDIO-GRAN\\t1052\",\n    \"01_MO_FIN\\t1148\",\n    \"02_MO_S_PACK\\t1148\"\n  ]\n}",
      "I need:\nGRAN,1052\n01_MO_FIN,1148\n02_MO_S_PACK,1148",
      "jq -r '.Rows[] | split(\"\\t\") | .[0]+\",\"+.[1]' < file.json",
      "jq -r '.Rows[] | split(\"\\t\") | @csv' < file.json"
    ],
    "utterance": "Extract each element of the Rows array, split each string at the tab character, and output the resulting pieces as comma-separated values.",
    "expressions": [
      ".Rows[] | split(\"\\t\") | .[0]+\",\"+.[1]",
      ".Rows[] | split(\"\\t\") | @csv"
    ],
    "data": [
      {
        "input": {
          "ProcessId": "5452",
          "TotalRows": 226171,
          "Rows": [
            "001-CARDIO-GRAN\t1052",
            "01_MO_FIN\t1148",
            "02_MO_S_PACK\t1148"
          ]
        },
        "output": [
          "001-CARDIO-GRAN,1052",
          "01_MO_FIN,1148",
          "02_MO_S_PACK,1148"
        ]
      }
    ],
    "identifier": 78103595,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Better yet, just do everything in jq.",
      "printf %s \"$entry\" | jq -r --arg item \"$item\" '\n   \"\\( $item )_USERNAME=\\( .login.username | @sh )\",\n   \"\\( $item )_PASSWORD=\\( .login.password | @sh )\",\n   \"\\( $item )_NOTES=\\(    .notes // \"\"    | @sh )\",\n   (\n      .fields[] |\n      ( .name | gsub( \" \"; \"_\" ) ) as $field_name  |\n      ( .value                   ) as $field_value |\n      \"\\( $item )_FIELD_\\( $field_name )=\\( $field_value | @sh )\"\n   )\n'\ndone"
    ],
    "utterance": "Produce environment variable assignments for username, password, notes, and each field with names normalized by replacing spaces with underscores; each value should be safely shell-escaped and prefixed by the item's UUID.",
    "expressions": [
      "\"\\($item)_USERNAME=\\(.login.username | @sh)\",\n\"\\($item)_PASSWORD=\\(.login.password | @sh)\",\n\"\\($item)_NOTES=\\(.notes // \"\" | @sh)\",\n(\n  .fields[] |\n  (.name | gsub(\" \"; \"_\")) as $field_name |\n  (.value) as $field_value |\n  \"\\($item)_FIELD_\\($field_name)=\\($field_value | @sh)\"\n)"
    ],
    "data": [
      {
        "input": {
          "passwordHistory": [
            {
              "lastUsedDate": "2024-02-23T17:10:59.343Z",
              "password": "versteckt_name-leerzeichen: versteckt_wert leerzeichen"
            },
            {
              "lastUsedDate": "2024-02-23T17:10:59.343Z",
              "password": "TestPasswort"
            },
            {
              "lastUsedDate": "2024-02-23T16:45:56.662Z",
              "password": "versteckt_name leerzeichen: versteckt_wert leerzeichen"
            },
            {
              "lastUsedDate": "2024-02-23T16:28:04.951Z",
              "password": "versteckt_name: versteckt_wert"
            }
          ],
          "revisionDate": "2024-02-23T17:14:48.810Z",
          "creationDate": "2024-02-18T21:04:02.811Z",
          "deletedDate": null,
          "object": "item",
          "id": "55f8864a-ec88-410c-ab0e-8bee2119042a",
          "organizationId": null,
          "folderId": null,
          "type": 1,
          "reprompt": 0,
          "name": "TestName",
          "notes": "notizen notizen1 notizen2",
          "favorite": false,
          "fields": [
            {
              "name": "benutzerdefiniert_name leerzeichen",
              "value": "benutzerdefiniert_wert leerzeichen",
              "type": 0,
              "linkedId": null
            },
            {
              "name": "versteckt_name leerzeichen",
              "value": "versteckt_wert leerzeichen",
              "type": 1,
              "linkedId": null
            },
            {
              "name": "bool_name leerzeichen",
              "value": "false",
              "type": 2,
              "linkedId": null
            }
          ],
          "login": {
            "fido2Credentials": [],
            "uris": [],
            "username": "TestBenutzername leerzeichen",
            "password": "TestPasswort leerzeichen",
            "totp": null,
            "passwordRevisionDate": "2024-02-23T17:10:59.343Z"
          },
          "collectionIds": []
        },
        "output": [
          "55f8864a-ec88-410c-ab0e-8bee2119042a_USERNAME='TestBenutzername leerzeichen'",
          "55f8864a-ec88-410c-ab0e-8bee2119042a_PASSWORD='TestPasswort leerzeichen'",
          "55f8864a-ec88-410c-ab0e-8bee2119042a_NOTES='notizen notizen1 notizen2'",
          "55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_benutzerdefiniert_name_leerzeichen='benutzerdefiniert_wert leerzeichen'",
          "55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_versteckt_name_leerzeichen='versteckt_wert leerzeichen'",
          "55f8864a-ec88-410c-ab0e-8bee2119042a_FIELD_bool_name_leerzeichen='false'"
        ]
      }
    ],
    "identifier": 78104546,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I am trying to use an arg substitution with jq and one of the args needs to be a key.",
      "key expressions at top level need parenthesis:",
      "This should work:",
      "($reg): {",
      "why not use `env`?",
      "\"\\(env.DOCKER_REGISTRY)\": {",
      "Output",
      "{\n  \"auths\": {\n    \"hub.docker.io\": {\n      \"username\": \"joe\",\n      \"password\": \"whatever\",\n      \"auth\": \"am9lOndoYXRldmVy\"\n    }\n  }\n}"
    ],
    "utterance": "Create an object where the key under 'auths' is set dynamically from a variable's value, and its value is an object with username, password, and a base64-encoded auth field, all populated from variables.",
    "expressions": [
      "{ \"auths\": { ($reg): { \"username\": $u, \"password\": $p, \"auth\": $auth } } }",
      "{ \"auths\": { \"\\(env.DOCKER_REGISTRY)\": { \"username\": env.USERNAME, \"password\": env.PASSWORD, \"auth\": (\"\\(env.USERNAME):\\(env.PASSWORD)\"|@base64) } } }"
    ],
    "data": [
      {
        "input": {
          "env": {
            "USERNAME": "joe",
            "PASSWORD": "whatever",
            "DOCKER_REGISTRY": "hub.docker.io"
          }
        },
        "output": {
          "auths": {
            "hub.docker.io": {
              "username": "joe",
              "password": "whatever",
              "auth": "am9lOndoYXRldmVy"
            }
          }
        }
      }
    ],
    "identifier": 78104993,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have a dictionary like:",
      "{\n    \"Items\": [\n        {\n            \"ID\": \"123abc\",\n            \"Name\": \"test name\",\n            \"Description\": \"item 1\"\n        },\n        {\n            \"ID\": \"321zyx\",\n            \"Name\": \"test name two\",\n            \"Description\": \"item 2\"\n        }\n    ]\n}",
      "I'd like to use `jq` to convert this into:",
      "{\n    \"123abc\": {\n        \"Name\": \"test name\",\n        \"Description\": \"item 1\"\n    },\n    \"321zyx\": {\n        \"Name\": \"test name two\",\n        \"Description\": \"item 2\"\n    }\n}",
      "If so, how would I accomplish this?",
      "To remove the `.ID` keys from the output, use `del` to update each key:\njq 'INDEX(.Items[]; .ID) | .[] |= del(.ID)'",
      "jq 'reduce .Items[] as $i ({}; .[$i.ID|tostring] = ($i | del(.ID)))'",
      "```\n.Items | map({key: .ID, value: del(.ID)}) | from_entries\n```\nproduces the desired output."
    ],
    "utterance": "Transform an object with an Items array of objects, each with an ID, Name, and Description, into an object whose keys are the ID values and whose values are objects containing Name and Description (excluding ID).",
    "expressions": [
      "INDEX(.Items[]; .ID) | .[] |= del(.ID)",
      "reduce .Items[] as $i ({}; .[$i.ID|tostring] = ($i | del(.ID)))",
      ".Items | map({key: .ID, value: del(.ID)}) | from_entries"
    ],
    "data": [
      {
        "input": {
          "Items": [
            {
              "ID": "123abc",
              "Name": "test name",
              "Description": "item 1"
            },
            {
              "ID": "321zyx",
              "Name": "test name two",
              "Description": "item 2"
            }
          ]
        },
        "output": {
          "123abc": {
            "Name": "test name",
            "Description": "item 1"
          },
          "321zyx": {
            "Name": "test name two",
            "Description": "item 2"
          }
        }
      }
    ],
    "identifier": 78108684,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "def min_size = sh(script: \"echo '${cfn_template}' | jq -r '.Resources.devfoenergybkrblueasgASG12345678.Properties.MinSize'\", returnStdout: true).trim()",
      "I also have a Groovy variable `asg_logical_id` that sores the value `devfoenergybkrblueasgASG12345678`. I'd like to use this variable in the command that is giving syntax error now, instead of this direct value.",
      "min_size=$(echo ${cfn_template} | jq -r '.Resources.devfoenergybkrblueasgASG12345678.Properties.MinSize')"
    ],
    "utterance": "Select the MinSize property from the Properties object of the Resource identified by the value of the asg_logical_id variable inside Resources.",
    "expressions": [
      ".Resources[env.asg_logical_id].Properties.MinSize",
      ".Resources[asg_logical_id].Properties.MinSize"
    ],
    "identifier": 78109928,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I'm using jq to extract an array from a JSON in a GitHub workflow:",
      "echo $(echo '{\"value\":[{\"displayName\":\"test\"}]}' | jq -c '.value.[]')",
      "If I run the same command with jq locally, it works - why doesn't it work on a GitHub runner?",
      "You're using `.value.[]`; support for chained `.[]` was added in jq 1.7",
      "You can fix it by using `.value[]` instead."
    ],
    "utterance": "Extract each element from the value array in the object where value is an array of objects.",
    "expressions": [
      ".value[]"
    ],
    "data": [
      {
        "input": {
          "value": [
            {
              "displayName": "test"
            }
          ]
        },
        "output": {
          "displayName": "test"
        }
      }
    ],
    "identifier": 78114596,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to display some amount of seconds that correspond to dime duration rather than regular date in some human-readable form. say sth like:",
      "[ 30300, 120300, 296700, 31922700, 63458700 ] and what i would like to get [ \"0d, 08:25\", \"1d, 09:25\", \"3d, 10:25\", \"1y 4d, 11:25\", \"2y 4d, 11:25\" ]",
      "Here is a way that doesn&#39;t use time builtins:",
      "map( [foreach ( [60, \"seconds\"], [60, \"minutes\"], [24, \"hours\"], [365, \"days\"], [false, \"years\"] ) as [$unit, $key] ( {in: .}; if $unit then {in: (.in/$unit | floor), out: {($key): (.in%$unit)}} else {out: {($key): .in}} end; .out )] | add | [ (.years | if . > 0 then \"\\(.)y\" else empty end), \"\\(.days)d,\", ([.hours, .minutes] | map(if . < 10 then \"0\\(.)\" else . end) | join(\":\")) ] | join(\" \") )",
      "Here is a solution written for flexibility and using a generic `seconds2object` function:",
      "[ 30300, 120300, 296700, 31922700, 63458700 ] | map(seconds2human)"
    ],
    "utterance": "Convert numbers of seconds into strings formatted as 'Yy Dd, HH:MM', omitting the years if zero and displaying days, hours, and minutes with zero-padding as needed.",
    "expressions": [
      "map([foreach ([60, \"seconds\"], [60, \"minutes\"], [24, \"hours\"], [365, \"days\"], [false, \"years\"]) as [$unit, $key] ({in: .}; if $unit then {in: (.in/$unit | floor), out: {($key): (.in%$unit)}} else {out: {($key): .in}} end; .out )] | add | [(.years | if . > 0 then \"\\(.)y\" else empty end), \"\\(.days)d,\", ([.hours, .minutes] | map(if . < 10 then \"0\\(.)\" else . end) | join(\":\")) ] | join(\" \"))",
      "def seconds2object: def divrem($x; $y): [$x/$y|floor, $x % $y]; def units: { min: 60} | .hour =  60 * .min | .day  =  24 * .hour | .year = 365 * .day; units as $units | divrem( .; $units.year) as [$years, $r] | divrem($r; $units.day)  as [$days, $r] | divrem($r; $units.hour) as [$hours, $r] | divrem($r; $units.min)  as [$mins, $secs] | {$years, $days, $hours, $mins, $secs} ; def seconds2human: def lpad($len): tostring | ($len - length) as $l | (\"0\" * $l) + .; seconds2object | if .years == 0 then \"\" else \"\\(.years)y \" end + \"\\(.days)d, \\(.hours|lpad(2)):\\(.mins|lpad(2))\" ; map(seconds2human)"
    ],
    "data": [
      {
        "input": [
          30300,
          120300,
          296700,
          31922700,
          63458700
        ],
        "output": [
          "0d, 08:25",
          "1d, 09:25",
          "3d, 10:25",
          "1y 4d, 11:25",
          "2y 4d, 11:25"
        ]
      }
    ],
    "identifier": 78115604,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "\"I'm looking for a result that looks like below ... \\n\\n    /api/device/4756, Arbitrator, 127.0.0.1, acme.arbitrate.com\\n    /api/device/4757, Auditor, 127.0.0.2, acme.auditor.com\\n    /api/device/4758, Augumentor, 127.0.0.3, acme.augumentor.com\"",
      "\"Then store the key to access it later:\\n```sh\\n.result_set | keys_unsorted[] as $key | .[$key] | [$key, .name, .ip, .hostname]\\n| join(\", \") # or @csv\\n```\"",
      "\"Or use [`to_entries`](https://jqlang.github.io/jq/manual/#to_entries-from_entries-with_entries) instead, which breaks up an object into a list of key-value pairs:\\n```sh\\n.result_set | to_entries[] | [.key, .value.name, .value.ip, .value.hostname]\\n| join(\", \") # or @csv\\n```\""
    ],
    "utterance": "List each device's key with its name, IP, and hostname, separated by commas.",
    "expressions": [
      ".result_set | keys_unsorted[] as $key | .[$key] | [$key, .name, .ip, .hostname] | join(\", \")",
      ".result_set | to_entries[] | [.key, .value.name, .value.ip, .value.hostname] | join(\", \")"
    ],
    "data": [
      {
        "input": {
          "result_set": {
            "/api/device/4756": {
              "name": "Arbitrator",
              "ip": "127.0.0.1",
              "hostname": "acme.arbitrate.com"
            },
            "/api/device/4757": {
              "name": "Auditor",
              "ip": "127.0.0.2",
              "hostname": "acme.auditor.com"
            },
            "/api/device/4758": {
              "name": "Augumentor",
              "ip": "127.0.0.3",
              "hostname": "acme.augumentor.com"
            }
          }
        },
        "output": [
          "/api/device/4756, Arbitrator, 127.0.0.1, acme.arbitrate.com",
          "/api/device/4757, Auditor, 127.0.0.2, acme.auditor.com",
          "/api/device/4758, Augumentor, 127.0.0.3, acme.augumentor.com"
        ]
      }
    ],
    "identifier": 78117813,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Need help converting this JSON and using a specific element of the Column Dimension as the Column header line in CSV using jq",
      "Required Output in CSV format ( I only the data below and the rest of the elements in JSON to be ignored).",
      "The header columns come from .Columns[].Id",
      "You need to collect the output rows into arrays. As for the headers, you have alreday given the path yourself: `.Columns[].Id`. And the actual rows are also already organized into an array.",
      "jq -r '[.Columns[].Id], .Rows[].Values | @csv'"
    ],
    "utterance": "Generate a CSV where the first row is the Id fields from Columns and the next rows are each Values array from Rows.",
    "expressions": [
      "[.Columns[].Id], .Rows[].Values | @csv"
    ],
    "data": [
      {
        "input": {
          "Columns": [
            {
              "Id": "ItemName",
              "IsEditable": false
            },
            {
              "Id": "Date",
              "IsEditable": false
            },
            {
              "Id": "Qty",
              "IsEditable": false
            }
          ],
          "Rows": [
            {
              "Values": [
                "ITEM1",
                "10-MAY-2024",
                "100"
              ]
            },
            {
              "Values": [
                "ITEM2",
                "20-MAY-2024",
                "200"
              ]
            },
            {
              "Values": [
                "ITEM3",
                "30-MAY-2024",
                "400"
              ]
            }
          ],
          "QueryHandle": {
            "QueryID": "00101",
            "Worksheet": {
              "Name": "Test20",
              "Scope": "NA"
            },
            "WorkAlloc": "2024-MAY"
          },
          "RowCount": 3
        },
        "output": "\"ItemName\",\"Date\",\"Qty\"\n\"ITEM1\",\"10-MAY-2024\",\"100\"\n\"ITEM2\",\"20-MAY-2024\",\"200\"\n\"ITEM3\",\"30-MAY-2024\",\"400\""
      }
    ],
    "identifier": 78118487,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have a json file in the following format",
      "and I'd like to know how to output something like this\n\na p1-value\na p2-value\na p3-value\nz p1-value",
      "Either use [`to_entries`](https://jqlang.github.io/jq/manual/#to_entries-from_entries-with_entries) to create an array of key-value pairs, which you can access by using `.key` and `.value`:\n```sh\nto_entries[] | \"\\(.key) \\(.value[][].p)\"\n```",
      "Or fetch just the keys using [`keys_unsorted`](https://jqlang.github.io/jq/manual/#keys-keys_unsorted), bind them to a variable using `as`, and access the fields using the variable:\n```sh\nkeys_unsorted[] as $key | \"\\($key) \\(.[$key][][].p)\"\n```"
    ],
    "utterance": "For each top-level key, output the key and all values of the nested field 'p', each on its own line, prefixed by the key.",
    "expressions": [
      "to_entries[] | \"\\(.key) \\(.value[][].p)\"",
      "keys_unsorted[] as $key | \"\\($key) \\(.[$key][][].p)\""
    ],
    "data": [
      {
        "input": {
          "a": [
            [
              {
                "p": "p1-value",
                "d": "d1-value"
              },
              {
                "p": "p2-value",
                "d": "d2-value"
              }
            ],
            [
              {
                "p": "p3-value",
                "d": "d3-value"
              }
            ]
          ],
          "z": [
            [
              {
                "p": "p1-value",
                "d": "d1-value"
              }
            ]
          ]
        },
        "output": [
          "a p1-value",
          "a p2-value",
          "a p3-value",
          "z p1-value"
        ]
      }
    ],
    "identifier": 78121993,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "So the scenario is `ticketId` and `requester_id` should become an attribute of each objects in `componentsByProdTourId` array.",
      "I tried this Jq command:\r\n\r\n    .componentsByProdTourId |= map(. + {ticketId: .ticketData.ticketId, requester_id: .ticketData.requester_id})\r\n\r\n \r\nBut the result was not ideal. `ticketId` and `requester_id` were null.",
      ".componentsByProdTourId[] += .ticketData\r\n\r\nis enough. Your version is failing because at the time when you try to access `.ticketData`, `.` is the item you&#39;re mapping over, and not the root object. You could fix that by using `as` to capture `.ticketData`, but there&#39;s an easier way which is to skip `map` entirely."
    ],
    "utterance": "Add the ticketId and requester_id from ticketData as attributes to each element in the componentsByProdTourId array.",
    "expressions": [
      ".componentsByProdTourId[] += .ticketData"
    ],
    "data": [
      {
        "input": {
          "componentsByProdTourId": [
            {
              "region": "Europe",
              "compSpec": {
                "country": "France",
                "attributes": [
                  {
                    "attributeCode": "ABC",
                    "attributeType": "xyx"
                  }
                ]
              }
            },
            {
              "region": "Europe",
              "compSpec": {
                "country": "France",
                "attributes": [
                  {
                    "attributeCode": "EFG",
                    "attributeType": "lmn"
                  }
                ]
              }
            },
            {
              "region": "Europe",
              "compSpec": {
                "country": "United Kingdom",
                "attributes": [
                  {
                    "attributeCode": "FLC",
                    "attributeType": "omp"
                  }
                ]
              }
            }
          ],
          "ticketData": {
            "ticketId": "1234",
            "requester_id": "99885"
          }
        },
        "output": {
          "componentsByProdTourId": [
            {
              "region": "Europe",
              "compSpec": {
                "country": "France",
                "attributes": [
                  {
                    "attributeCode": "ABC",
                    "attributeType": "xyx"
                  }
                ]
              },
              "ticketId": "1234",
              "requester_id": "99885"
            },
            {
              "region": "Europe",
              "compSpec": {
                "country": "France",
                "attributes": [
                  {
                    "attributeCode": "EFG",
                    "attributeType": "lmn"
                  }
                ]
              },
              "ticketId": "1234",
              "requester_id": "99885"
            },
            {
              "region": "Europe",
              "compSpec": {
                "country": "United Kingdom",
                "attributes": [
                  {
                    "attributeCode": "FLC",
                    "attributeType": "omp"
                  }
                ]
              },
              "ticketId": "1234",
              "requester_id": "99885"
            }
          ],
          "ticketData": {
            "ticketId": "1234",
            "requester_id": "99885"
          }
        }
      }
    ],
    "identifier": 78128389,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to add one more variable to the filtering, preferably \"contains\" as I want to filter this one based on a OS field which contains different strings",
      ".results[] | select(.cluster.name == $cluster and .cluster.os == $os) | .primary_ip.address",
      ".results[] | select(.cluster.name == $cluster) | select(.cluster.os | contains($os)) | .primary_ip.address"
    ],
    "utterance": "Return the primary_ip.address fields from results where cluster.name equals the specified cluster and cluster.os contains the given substring.",
    "expressions": [
      ".results[] | select(.cluster.name == $cluster and (.cluster.os | contains($os))) | .primary_ip.address",
      ".results[] | select(.cluster.name == $cluster) | select(.cluster.os | contains($os)) | .primary_ip.address"
    ],
    "identifier": 78131884,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "and i want to get the name of each field, with it's type and eventually it's default value (null in the case of productQuantity).",
      "So the output should but something like :",
      "\"shopId\" string",
      "\"productId\" string",
      "...",
      "\"timestampTransmission\" long",
      "\"productQuantity\" double null",
      "If I correctly understand your formatting, you want",
      ".fields[] | [",
      "  \"\\\"\\(.name)\\\"\",",
      "  (.type | objects.type // arrays[] // . | select(. != \"null\")),",
      "  (select(has(\"default\")).default | tostring)",
      "] | join(\" \")"
    ],
    "utterance": "List each field's name, its type, and include its default value if present as null for that field.",
    "expressions": [
      ".fields[] | [\"\\\"\\(.name)\\\"\", (.type | objects.type // arrays[] // . | select(. != \"null\")), (select(has(\"default\")).default | tostring)] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "type": "record",
          "name": "ShelfEx \u00bbposition",
          "fields": [
            {
              "name": "shopId",
              "type": {
                "type": "string",
                "avro.java.string": "String"
              },
              "doc": "Id of the shop"
            },
            {
              "name": "productId",
              "type": {
                "type": "string",
                "avro.java.string": "String"
              },
              "doc": "Id of the product"
            },
            {
              "name": "sourceId",
              "type": {
                "type": "string",
                "avro.java.string": "String"
              },
              "doc": "Id of the source"
            },
            {
              "name": "timestampTransmission",
              "type": "long",
              "doc": "Timestamp of the message"
            },
            {
              "name": "productQuantity",
              "type": [
                "null",
                "double"
              ],
              "doc": "Quantity of the product",
              "default": null
            }
          ]
        },
        "output": [
          "\"shopId\" string",
          "\"productId\" string",
          "\"sourceId\" string",
          "\"timestampTransmission\" long",
          "\"productQuantity\" double null"
        ]
      }
    ],
    "identifier": 78143536,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I just want the exact same json, but filtering out prop3,prop4 and nestedprop2, or in other words, I want to filter in the whole tree for prop1, prop2 and nestedprop1",
      ".data[] |= del(.prop3, .prop4, .nestedprops.nestedprop2)",
      "To omit specific keys at all levels, you could use `walk`, e.g.\n\nwalk(if type == \"object\" then del(.prop3, .prop4, .nestedprop2) end)",
      ".data[] |= (pick(.prop1, .prop2, .nestedprops.nestedprop1 | values) // {})",
      "def keep:\n  if type == \"object\"\n  then if has(\"prop1\") or has(\"prop2\") or has(\"nestedprops\")\n       then {prop1, prop2, nestedprops} | with_entries( if .value == null then empty end)\n       elif has(\"nestedprop1\") then {nestedprop1}\n       else {}\n       end\n  else .\n  end;\n\n.data |= walk(keep)"
    ],
    "utterance": "Return the original structure but remove prop3, prop4, and nestedprop2 at all levels, so only prop1, prop2, and nestedprop1 remain, including inside nested objects.",
    "expressions": [
      ".data[] |= del(.prop3, .prop4, .nestedprops.nestedprop2)",
      "walk(if type == \"object\" then del(.prop3, .prop4, .nestedprop2) end)",
      ".data[] |= (pick(.prop1, .prop2, .nestedprops.nestedprop1 | values) // {})",
      "def keep:\n  if type == \"object\"\n  then if has(\"prop1\") or has(\"prop2\") or has(\"nestedprops\")\n       then {prop1, prop2, nestedprops} | with_entries( if .value == null then empty end)\n       elif has(\"nestedprop1\") then {nestedprop1}\n       else {}\n       end\n  else .\n  end;\n\n.data |= walk(keep)"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "prop1": "a",
              "prop2": "b",
              "prop3": "c",
              "prop4": "d",
              "nestedprops": {
                "nestedprop1": "A",
                "nestedprop2": "B"
              }
            },
            {
              "prop2": "b",
              "prop3": "c",
              "nestedprops": {
                "nestedprop1": "A"
              }
            },
            {
              "prop3": "c"
            }
          ]
        },
        "output": {
          "data": [
            {
              "prop1": "a",
              "prop2": "b",
              "nestedprops": {
                "nestedprop1": "A"
              }
            },
            {
              "prop2": "b",
              "nestedprops": {
                "nestedprop1": "A"
              }
            },
            {}
          ]
        }
      }
    ],
    "identifier": 78157031,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "cat * | jq '.cis[].properties.cloud_vm_display_name' | grep -v null",
      "Need to extract cloud VM name from multiple json files where the array number is different in every file.",
      "Even better, don't use grep at all, but filter with jq directly: .cis[].properties.cloud_vm_display_name | values"
    ],
    "utterance": "Extract all non-null cloud_vm_display_name values from all objects in the cis array across multiple files.",
    "expressions": [
      ".cis[].properties.cloud_vm_display_name | values"
    ],
    "identifier": 78166506,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": true,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Now my problem: I&#39;m struggling with doing some math on the fly. I want to subtract `seen_pos` from `now` and use that value in the result.",
      "I can&#39;t figure out how to access `now` from the outer array. Would you kindly nudge me in the right direction?",
      "You&#39;ll need to remember `.now` before looping (`[]`) deeper.",
      "Start your filter with `.now as $now | ...`",
      "Then in the array you create to keep some data, you can use `$now` as needed:",
      "    .now as $now \n    | .aircraft[] \n    | [.lon, .lat, .alt_baro, .seen_pos, .hex, ($now - .seen_pos) ] \n    | select(.[0] &gt; 7) | select(.[0] &lt; 10) | select(.[1] &gt; 49) | select(.[1] &lt; 51) | select(.[2] != null) | select(.[2] != \"ground\") | select(.[2] &lt; 13000) \n    | @csv",
      "Output:\n7.385010,49.848068,5250,0.180,\"3c4dc5\",1685613599.699"
    ],
    "utterance": "Produce a list of fields for each aircraft that matches given lon, lat, and alt_baro filters, but with an additional field where seen_pos is subtracted from now.",
    "expressions": [
      ".now as $now | .aircraft[] | [.lon, .lat, .alt_baro, .seen_pos, .hex, ($now - .seen_pos)] | select(.[0] > 7) | select(.[0] < 10) | select(.[1] > 49) | select(.[1] < 51) | select(.[2] != null) | select(.[2] != \"ground\") | select(.[2] < 13000) | @csv"
    ],
    "data": [
      {
        "input": {
          "now": 1685613599.879,
          "messages": 1347296469,
          "aircraft": [
            {
              "hex": "7c806e",
              "type": "adsc",
              "flight": "QF94    ",
              "r": "VH-ZNK",
              "t": "B789",
              "alt_baro": 34000,
              "gs": 475.0,
              "track": 231.55,
              "lat": 12.694702,
              "lon": -146.52586,
              "nic": 0,
              "rc": 0,
              "seen_pos": 24.752,
              "alert": 0,
              "spi": 0,
              "mlat": [],
              "tisb": [],
              "messages": 6145890,
              "seen": 24.8,
              "rssi": -49.5
            },
            {
              "hex": "3c4dc5",
              "type": "adsb_icao",
              "flight": "DLH9LL  ",
              "r": "D-ACNE",
              "t": "CRJ9",
              "alt_baro": 5250,
              "gs": 253.3,
              "track": 182.72,
              "lat": 49.848068,
              "lon": 7.38501,
              "nic": 8,
              "rc": 186,
              "seen_pos": 0.18,
              "alert": 0,
              "spi": 0,
              "mlat": [],
              "tisb": [],
              "messages": 9278490,
              "seen": 0.2,
              "rssi": -9.7
            }
          ]
        },
        "output": "7.385010,49.848068,5250,0.180,\"3c4dc5\",1685613599.699"
      }
    ],
    "identifier": 78168096,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "But how can I script merging of an arbitrary number of files without writing intermediate versions?",
      "You can do it with a single call to jq like this :",
      "jq -n 'reduce inputs as $i({};. * $i)' file{1..4}.json",
      "Be aware that `*` potentially does more than you might think.",
      "The \"+\" operator on objects is much less complicated, so chances are that something like the following will meet your needs:",
      "jq -n '[inputs] | add' file*.json"
    ],
    "utterance": "Merge an arbitrary number of files into a single object using object multiplication or addition operators without intermediate files.",
    "expressions": [
      "jq -n 'reduce inputs as $i ({}; . * $i)' file*.json",
      "jq -n '[inputs] | add' file*.json"
    ],
    "identifier": 78173589,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": true,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "My desired result would be:\n```\nAQ_01_Availability\nAQ_01_CO2\nAQ_01_Formaldehyde\nAQ_01_Humidity\n```",
      "You want to extract all keys of that top-level object. `jq` provides two functions that provide those keys in an array: [`keys` and `keys_unsorted`](https://jqlang.github.io/jq/manual/#keys-keys_unsorted).",
      "to get your desired output, iterate over that array using [`.[]`](https://jqlang.github.io/jq/manual/#array-object-value-iterator). You can combine the function and the iterator to:\n```sh\njq -r 'keys_unsorted[]' items.json\n# or\njq -r 'keys[]' items.json\n```"
    ],
    "utterance": "List all top-level object keys in their original order.",
    "expressions": [
      "keys_unsorted[]",
      "keys[]"
    ],
    "data": [
      {
        "input": {
          "AQ_01_Availability": {
            "class": "org.openhab.core.items.ManagedItemProvider$PersistedItem",
            "value": {
              "groupNames": [
                "gAirQuality_01"
              ],
              "itemType": "Switch",
              "tags": [],
              "label": "Availability"
            }
          },
          "AQ_01_CO2": {
            "class": "org.openhab.core.items.ManagedItemProvider$PersistedItem",
            "value": {
              "groupNames": [
                "gAirQuality_01"
              ],
              "itemType": "Number",
              "tags": [],
              "label": "CO2"
            }
          },
          "AQ_01_Formaldehyde": {
            "class": "org.openhab.core.items.ManagedItemProvider$PersistedItem",
            "value": {
              "groupNames": [
                "gAirQuality_01"
              ],
              "itemType": "Number",
              "tags": [],
              "label": "Formaldehyde"
            }
          },
          "AQ_01_Humidity": {
            "class": "org.openhab.core.items.ManagedItemProvider$PersistedItem",
            "value": {
              "groupNames": [
                "gAirQuality_01"
              ],
              "itemType": "Number",
              "tags": [],
              "label": "Humidity",
              "category": "humidity"
            }
          }
        },
        "output": [
          "AQ_01_Availability",
          "AQ_01_CO2",
          "AQ_01_Formaldehyde",
          "AQ_01_Humidity"
        ]
      }
    ],
    "identifier": 78177249,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I tried to query the existing hosts inside the rule with",
      "TESTOUTPUT=$(aws elbv2 describe-rules --rule-arns arn:aws:elasticloadbalancing:ap-northeast-1:xxxx:listener-rule/app/k8s-ctrlroute-xxx/xxx/xxx --region ap-northeast-1 --no-cli-pager | jq [.Rules[0].Conditions[0].Values[]])",
      "The result are the expected hosts. It looks like",
      "[ \"host1.cloud\", \"host2.cloud\", \"host3.cloud\" ]",
      "If you want to get the output in a Bash array, try",
      "jq '[.Rules[0].Conditions[0].Values[]] | @sh'",
      "echo '{\"Rules\": [ { \"Conditions\":[ { \"Values\": [ \"host1.cloud\", \"host2.cloud\", \"host3.cloud\" ] } ] } ] }' |jq '.Rules[0].Conditions[0].Values += [\"host4.cloud\"]'"
    ],
    "utterance": "Select the list of hosts from the first Conditions Values array under the first Rules element.",
    "expressions": [
      ".Rules[0].Conditions[0].Values"
    ],
    "data": [
      {
        "input": {
          "Rules": [
            {
              "Conditions": [
                {
                  "Values": [
                    "host1.cloud",
                    "host2.cloud",
                    "host3.cloud"
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "host1.cloud",
          "host2.cloud",
          "host3.cloud"
        ]
      }
    ],
    "identifier": 78180419,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I\u2019d like to get a list of all paths available in a JSON document, just to get an idea of the layout of a big json document.",
      "Use `jq -r 'paths | map(numbers |= \"[\\(.)]\") | join(\".\")'`.",
      "A more succinct expression like `paths | join(\".\")` will render array indices and numeric object keys the same way. That might be not desirable.",
      "This version handles the cases where keys are not identifiers (have spaces, etc.), and the result can be given back to jq :",
      "jq -r '\n    paths | (if (first|type)==\"string\" then \"\" else \".\" end) + (map(\n        if type==\"string\"\n        then \".\" +\n             if test(\"^[a-zA-Z_][a-zA-Z_0-9]*$\")\n             then .\n             else .|tojson\n             end\n        else \"[\\(.)]\"\n        end) |\n        join(\"\")\n    )'",
      "To get just the paths of the keys (including the key), consider starting with:\npaths\n| select(.[-1] | type == \"string\")",
      "For example:\n[{a:1},{\"a b\":[{c:\"2\"}]}]\n| paths\n| select(.[-1] | type == \"string\")\nyields:\n[0,\"a\"]\n[1,\"a b\"]\n[1,\"a b\",0,\"c\"]",
      "jq '[paths|(map(if type == \"number\" then \"[]\" else \".\\(.)\" end)|join(\"\"))]|unique'"
    ],
    "utterance": "List all possible key paths in the document, including nested keys, using a concise one-liner; array indices and special key cases should be distinguishable and correctly represented.",
    "expressions": [
      "paths | map(numbers |= \"[\\(.)]\") | join(\".\")",
      "paths | join(\".\")",
      "paths | (if (first|type)==\"string\" then \"\" else \".\" end) + (map(if type==\"string\" then \".\" + (if test(\"^[a-zA-Z_][a-zA-Z_0-9]*$\") then . else .|tojson end) else \"[\\(.)]\" end) | join(\"\"))",
      "paths | select(.[-1] | type == \"string\")",
      "[paths|(map(if type == \"number\" then \"[]\" else \".\\(.)\" end)|join(\"\"))]|unique"
    ],
    "data": [
      {
        "input": {
          "k1": {
            "k12": "v12"
          },
          "k2": {
            "k21": {
              "k211": "v211"
            }
          }
        },
        "output": [
          "k1",
          "k1.k12",
          "k2",
          "k2.k21",
          "k2.k21.k211"
        ]
      },
      {
        "input": [
          {
            "a": 1
          },
          {
            "a b": [
              {
                "\u03c0": 3.14
              }
            ]
          }
        ],
        "output": [
          "[0]",
          "[0].a",
          "[1]",
          "[1].\"a b\"",
          "[1].\"a b\"[0]",
          "[1].\"a b\"[0].\"\u03c0\""
        ]
      }
    ],
    "identifier": 78181026,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "To add or modify a key in `dependencies`, use the following syntax:",
      "jq '.dependencies[\"foo\"]=\"1.1.1\"' \"package.json\"",
      "To add a key and value to an object, you can simply use",
      "object[\"key\"] = value",
      ".dependencies[ \"foo\" ] = \"3.3.3\" | .dependencies[ \"bar\" ] = \"2.2.2\"",
      "What if you wanted to add `.dependencies` only if it didn't already exist? Replace",
      ".dependencies = { }",
      "with",
      ".dependencies //= { }"
    ],
    "utterance": "Add or update the 'foo' package with version '3.3.3' and the 'bar' package with version '2.2.2' under the 'dependencies' field, creating 'dependencies' if it does not exist.",
    "expressions": [
      ".dependencies //= {}; .dependencies[\"foo\"] = \"3.3.3\"; .dependencies[\"bar\"] = \"2.2.2\""
    ],
    "data": [
      {
        "input": {},
        "output": {
          "dependencies": {
            "foo": "3.3.3",
            "bar": "2.2.2"
          }
        }
      },
      {
        "input": {
          "dependencies": {
            "foo": "1.1.1"
          }
        },
        "output": {
          "dependencies": {
            "foo": "3.3.3",
            "bar": "2.2.2"
          }
        }
      }
    ],
    "identifier": 78195387,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I m trying to replace a string value in a yaml file and I m not able to get the `if` working.",
      "First select the items you want to update (`\u2026[] | select(\u2026) | \u2026`), then update them (`\u2026 = \"new_release_version\"`).",
      "An alternative way of writing the program is:",
      "yq e '(\n  .spec.groups[]\n  | select(.name == \"deep_learning\").items[]\n  | select(.name == \"triton_release_version\")\n).default = \"new_release_version\"' config.yaml"
    ],
    "utterance": "Update the 'default' value of the item named 'triton_release_version' within the group named 'deep_learning' to 'new_release_version'.",
    "expressions": [
      ".spec.groups[] | select(.name == \"deep_learning\").items[] | select(.name == \"triton_release_version\").default = \"new_release_version\"",
      "(.spec.groups[] | select(.name == \"deep_learning\").items[] | select(.name == \"triton_release_version\")).default = \"new_release_version\""
    ],
    "data": [
      {
        "input": {
          "apiVersion": "kots.io/v1beta1",
          "kind": "Config",
          "metadata": {
            "name": "enterprise"
          },
          "spec": {
            "groups": [
              {
                "name": "api_authorization",
                "title": "API Authorization",
                "items": [
                  {
                    "name": "api_key",
                    "title": "API Key",
                    "type": "password",
                    "required": true
                  },
                  {
                    "name": "workspace_id",
                    "title": "Workspace ID",
                    "type": "text",
                    "required": true
                  }
                ]
              },
              {
                "name": "deep_learning",
                "title": "Deep Learning",
                "description": "Deep Learning Service Options",
                "items": [
                  {
                    "name": "triton_release_options",
                    "title": "Release Options",
                    "type": "heading"
                  },
                  {
                    "name": "triton_release_version",
                    "title": "Triton Release Version",
                    "type": "text",
                    "default": "release-v308",
                    "required": true
                  },
                  {
                    "name": "tracker_release_version",
                    "title": "Tracker Version",
                    "type": "text",
                    "default": "release-v308",
                    "required": true
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "apiVersion": "kots.io/v1beta1",
          "kind": "Config",
          "metadata": {
            "name": "enterprise"
          },
          "spec": {
            "groups": [
              {
                "name": "api_authorization",
                "title": "API Authorization",
                "items": [
                  {
                    "name": "api_key",
                    "title": "API Key",
                    "type": "password",
                    "required": true
                  },
                  {
                    "name": "workspace_id",
                    "title": "Workspace ID",
                    "type": "text",
                    "required": true
                  }
                ]
              },
              {
                "name": "deep_learning",
                "title": "Deep Learning",
                "description": "Deep Learning Service Options",
                "items": [
                  {
                    "name": "triton_release_options",
                    "title": "Release Options",
                    "type": "heading"
                  },
                  {
                    "name": "triton_release_version",
                    "title": "Triton Release Version",
                    "type": "text",
                    "default": "new_release_version",
                    "required": true
                  },
                  {
                    "name": "tracker_release_version",
                    "title": "Tracker Version",
                    "type": "text",
                    "default": "release-v308",
                    "required": true
                  }
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 78199185,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "jq --argjson timestamp \"$`date +%s`\" '.common |= . + {\"TimeValue\": $timestamp }' ${service}/${env}.json > tmpfile && mv tmpfile ${service}/${env}.json",
      "jq: invalid JSON text passed to --argjson",
      "jq --argjson timestamp `date +%s` '.common |= . + {\"TimeValue\": $timestamp }' ${service}/${env}.json > tmpfile && mv tmpfile ${service}/${env}.json",
      "timestamp=`date +%s`\njq --argjson timestamp $timestamp '.common |= . + {\"TimeValue\": $timestamp }' ${service}/${env}.json > tmpfile && mv tmpfile ${service}/${env}.json"
    ],
    "utterance": "Insert the current Unix timestamp as a TimeValue field into the common object in a file located at ${service}/${env}.json",
    "expressions": [
      "jq --argjson timestamp `date +%s` '.common |= . + {\"TimeValue\": $timestamp }' ${service}/${env}.json > tmpfile && mv tmpfile ${service}/${env}.json",
      "timestamp=`date +%s`\njq --argjson timestamp $timestamp '.common |= . + {\"TimeValue\": $timestamp }' ${service}/${env}.json > tmpfile && mv tmpfile ${service}/${env}.json"
    ],
    "identifier": 78207829,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": true,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "if ! jq -s '[0] == .[1]' \"$FILE_NAME\" \"s3-$FILE_NAME\" &> /dev/null; then",
      "I am simply looking to create a temp s3 file and initialize it with the s3 version, compare the temp s3 with the local, if there are differences than I want to have the temp s3 file get the latest updates and then after the s3 file is updated to remove the temp files.",
      "I have not been able to get the if condition to correctly determine when .json files are the same vs. when they are not."
    ],
    "utterance": "Check whether two files contain equal data.",
    "expressions": [
      "jq -s '.[0] == .[1]' file1.json file2.json"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": 2
          },
          {
            "a": 1,
            "b": 2
          }
        ],
        "output": true
      },
      {
        "input": [
          {
            "a": 1,
            "b": 2
          },
          {
            "a": 2,
            "b": 3
          }
        ],
        "output": false
      }
    ],
    "identifier": 78221337,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": true,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "db_secret_str=$(echo \"$db_secret_data\" | jq --arg keyvar \"${uid_str}-TY\" '.SecretString.[$keyvar]' -r)",
      "jq: error: syntax error, unexpected '['...",
      "Remove the dot before the key:\n\n    .SecretString[$keyvar]"
    ],
    "utterance": "Access the value in the SecretString object whose key is given by the variable keyvar.",
    "expressions": [
      ".SecretString[$keyvar]"
    ],
    "identifier": 78221461,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "original array:\n`output = ['one', 'two']`\n\ndesired output:\n`'[",
      "$(jq -c -n '$ARGS.positional' --args \"${output[@]}\")",
      "service_list_json=$(jq -c -n '$ARGS.positional' --args \"${output[@]}\")",
      "echo \"$service_list_json\"",
      "Output:\n[\"one\",\"two\"]"
    ],
    "utterance": "Convert a bash array with elements one and two into a compact string representation of the array, assigning it to a variable.",
    "expressions": [
      "jq -c -n '$ARGS.positional' --args \"${output[@]}\""
    ],
    "data": [
      {
        "input": {
          "bash_array": [
            "one",
            "two"
          ]
        },
        "output": "[\"one\",\"two\"]"
      }
    ],
    "identifier": 78227591,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to get down to the values in Wind / Direction.",
      "cat accuweather_raw | jq \".Wind[].Direction[] | [.Localized]\"",
      "The filter is not quite correct. You need to do,",
      ".[].Wind.Direction | [.Localized]",
      "Remember you are accessing an array at the top level, so `.[]` selects the objects within. And `Wind` is an object and not an array, so just `.Wind` is needed to access the sub-element `.Direction`."
    ],
    "utterance": "Extract the Localized value under Wind.Direction for each object in the top-level array.",
    "expressions": [
      ".[].Wind.Direction | [.Localized]"
    ],
    "data": [
      {
        "input": [
          {
            "LocalObservationDateTime": "2024-03-27T21:32:00-05:00",
            "EpochTime": 1711593120,
            "WeatherText": "Clear",
            "WeatherIcon": 33,
            "HasPrecipitation": false,
            "PrecipitationType": null,
            "IsDayTime": false,
            "Temperature": {
              "Metric": {
                "Value": 20,
                "Unit": "C",
                "UnitType": 17
              },
              "Imperial": {
                "Value": 68,
                "Unit": "F",
                "UnitType": 18
              }
            },
            "RealFeelTemperature": {
              "Metric": {
                "Value": 17.8,
                "Unit": "C",
                "UnitType": 17,
                "Phrase": "Pleasant"
              },
              "Imperial": {
                "Value": 64,
                "Unit": "F",
                "UnitType": 18,
                "Phrase": "Pleasant"
              }
            },
            "RealFeelTemperatureShade": {
              "Metric": {
                "Value": 17.8,
                "Unit": "C",
                "UnitType": 17,
                "Phrase": "Pleasant"
              },
              "Imperial": {
                "Value": 64,
                "Unit": "F",
                "UnitType": 18,
                "Phrase": "Pleasant"
              }
            },
            "RelativeHumidity": 62,
            "IndoorRelativeHumidity": 63,
            "DewPoint": {
              "Metric": {
                "Value": 12.8,
                "Unit": "C",
                "UnitType": 17
              },
              "Imperial": {
                "Value": 55,
                "Unit": "F",
                "UnitType": 18
              }
            },
            "Wind": {
              "Direction": {
                "Degrees": 90,
                "Localized": "E",
                "English": "E"
              }
            }
          }
        ],
        "output": [
          [
            "E"
          ]
        ]
      }
    ],
    "identifier": 78236176,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have a JSON object and would like to update for example the array element \"role[test09]\" to \"role[hello]\", I don't have the index number.",
      "A simple replacement with both, the old and the new values provided explicitly, would be to traverse to the desired item by iteration and selection, then using that as the LHS for an assignment:",
      "jq '(.run_list[] | select(. == \"role[test09]\")) = \"role[hello]\"' input.json"
    ],
    "utterance": "Update the array element with value \"role[test09]\" to \"role[hello]\", without knowing its index.",
    "expressions": [
      "(.run_list[] | select(. == \"role[test09]\")) = \"role[hello]\""
    ],
    "data": [
      {
        "input": {
          "run_list": [
            "role[test01]",
            "role[test09]",
            "role[test05]"
          ]
        },
        "output": {
          "run_list": [
            "role[test01]",
            "role[hello]",
            "role[test05]"
          ]
        }
      }
    ],
    "identifier": 78237633,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "JQ has a built-in `env` function that refers to the current environment and exposes it as a dictionary.",
      "Thus, all you need is:",
      "jq -n env >src/assets/config.json",
      "...or, to merge an existing config file to add new keys from the environment (and overwrite existing keys where they conflict):",
      "jq '. * env' <src/assets/config.json >src/assets/config.json.\"$$\""
    ],
    "utterance": "Merge the current environment variables into an existing config file, overwriting config keys with the environment values where they conflict.",
    "expressions": [
      "jq '. * env' <src/assets/config.json >src/assets/config.json.$$"
    ],
    "identifier": 78239304,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "How can I put the output to a json object like this:\r\n\r\n[\r\n   {\r\n      \"name\":\"fish\",\r\n      \"version\":\"3.7.0\"\r\n   },\r\n   {\r\n      \"name\":\"ncurses\",\r\n      \"version\":\"6.4\"\r\n   }\r\n]\r\n",
      "You can get directly json format with `brew info`:\r\n\r\nbrew info --json --installed | jq 'map({name, version:.installed[0].version})'"
    ],
    "utterance": "Produce an array of objects with fields name and version for each installed brew package, using the current package name and its first installed version.",
    "expressions": [
      "map({name, version:.installed[0].version})"
    ],
    "identifier": 78239630,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "commandOutput=$(eval $myJson | jq '.data')",
      "As you can see from the trace which you have posted, `commandOutput` does not hold the string `true`, but the string `\"true\"`, so you have to test for this:",
      "echo '{\"data\":\"true\"}' | jq -r '.data'",
      "But you don't need to compare the string in your shell at all, you can do the comparison directly in jq and leverage the [`-e`/`--exit-status` flag](https://jqlang.github.io/jq/manual/#invoking-jq) to set the exit code from jq:",
      "if echo '{\"data\":\"true\"}' | jq -re '.data==\"true\"' >/dev/null; then\n  echo 'data was \"true\"'\nfi"
    ],
    "utterance": "Extract the value of the 'data' field as a plain string without quotes, or check if the 'data' field equals 'true'.",
    "expressions": [
      ".data",
      ".data==\"true\"",
      ".data",
      ".data==\"true\""
    ],
    "data": [
      {
        "input": {
          "data": "true"
        },
        "output": "true"
      }
    ],
    "identifier": 78240671,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": true
      },
      "other_task": "The task description is ambiguous: it asks for two different things (extract as plain string without quotes, or check if equals 'true'), but only provides an example for one. It is unclear which behavior is required for other possible inputs.",
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to modify `\"a_string\"` to say `\"b_string\"` and the `properties` block of `foo` with something like `jq '(.arrays[]| select(.name == \"foo\")).sources |= [{\"type\" : \"sometypeB\", \"file\" : \"filename\"}]'`.",
      "But `select(.name == \"foo\")` fails here due to the string not having any `name`, any idea how I can modify both?",
      "The final json should look like:",
      "{\n\"arrays\": [\n    \"b_string\",\n    {\n      \"name\": \"foo\",\n      \"properties\": [\n        {\n          \"type\": \"sometypeB\",\n          \"file\": \"filename\"\n        }\n      ]\n    },\n    \"another_string\",\n    {\n      \"name\": \"bar\",\n      \"properties\": [\n        {\n          \"type\": \"some_type2\",\n          \"url\": \"https://example.org\",\n          \"checksum\": \"d6fd580fe890b826250aa5d5a88bcdb28839cff4d447ba51536cda4ceae89c4e\"\n        }\n      ]\n    }\n  ]\n}",
      "Here is a way:\n```\n.arrays | map(\n  select(. == \"a_string\") = \"b_string\"\n| select(objects | .name == \"foo\") .properties = [{type: \"sometypeB\", file: \"filename\"}]\n)\n```"
    ],
    "utterance": "Change the element \"a_string\" to \"b_string\" and replace the properties array of the object with name equal to \"foo\" with [{\"type\": \"sometypeB\", \"file\": \"filename\"}].",
    "expressions": [
      ".arrays |= map((if . == \"a_string\" then \"b_string\" elif (type == \"object\" and .name == \"foo\") then .properties = [{\"type\": \"sometypeB\", \"file\": \"filename\"}] | . else . end))"
    ],
    "data": [
      {
        "input": {
          "arrays": [
            "a_string",
            {
              "name": "foo",
              "properties": [
                {
                  "type": "some_type1",
                  "url": "https://example.com",
                  "checksum": "d6fd580fe890b826250aa5d5a88bcdb28839cff4d447ba51536cda4ceae89c4e"
                }
              ]
            },
            "another_string",
            {
              "name": "bar",
              "properties": [
                {
                  "type": "some_type2",
                  "url": "https://example.org",
                  "checksum": "d6fd580fe890b826250aa5d5a88bcdb28839cff4d447ba51536cda4ceae89c4e"
                }
              ]
            }
          ]
        },
        "output": {
          "arrays": [
            "b_string",
            {
              "name": "foo",
              "properties": [
                {
                  "type": "sometypeB",
                  "file": "filename"
                }
              ]
            },
            "another_string",
            {
              "name": "bar",
              "properties": [
                {
                  "type": "some_type2",
                  "url": "https://example.org",
                  "checksum": "d6fd580fe890b826250aa5d5a88bcdb28839cff4d447ba51536cda4ceae89c4e"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 78241769,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to change `properties` block of the array whose `name` is `foo`. The expected output is:",
      "Something like `.arrays[]| select(.name == \"foo\").sources |= [{\"type\" : \"foo\", \"url\" : \"bar\"}]` results in `jq: error (at <stdin>:26): Cannot index string with string \"name\"`",
      "You were close. Try this:",
      ".arrays |= map(select(objects | .name == \"foo\") .properties = [{type : \"foo\", url : \"bar\"}])"
    ],
    "utterance": "Modify the properties field of the array element with name equal to \"foo\" to a new value [{\"type\": \"foo\", \"url\": \"bar\"}].",
    "expressions": [
      ".arrays |= map(select(objects | .name == \"foo\") .properties = [{type : \"foo\", url : \"bar\"}])"
    ],
    "data": [
      {
        "input": {
          "header": "headername",
          "arrays": [
            "a_string",
            {
              "name": "foo",
              "properties": [
                {
                  "type": "some_type1",
                  "url": "https://example.com",
                  "checksum": "d6fd580fe890b826250aa5d5a88bcdb28839cff4d447ba51536cda4ceae89c4e"
                }
              ]
            },
            "another_string",
            {
              "name": "bar",
              "properties": [
                {
                  "type": "some_type2",
                  "url": "https://example.org",
                  "checksum": "d6fd580fe890b826250aa5d5a88bcdb28839cff4d447ba51536cda4ceae89c4e"
                }
              ]
            }
          ]
        },
        "output": {
          "header": "headername",
          "arrays": [
            "a_string",
            {
              "name": "foo",
              "properties": [
                {
                  "type": "foo",
                  "url": "bar"
                }
              ]
            },
            "another_string",
            {
              "name": "bar",
              "properties": [
                {
                  "type": "some_type2",
                  "url": "https://example.org"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 78241999,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "What I want to do is extract PORTION of the `key1` value - the bits between `delimiter1` and `delimiter2` which would be **_FIRST_IMPORTANT_VALUE_** and **_SECOND_IMPORTANT_VALUE_**",
      "So I need a more generalised form of the `jq '.foo[].bar.second | (.key1[23:46]),  .key2'` that replaces the numbers `23` and `46` with values determined from **delimiter1** and **delimiter2**",
      "Using a regex:\n```\n.foo[].bar.second\n| (.key1 | capture(\"delimiter1(?<v>.*)delimter2\").v)\n, .key2\n```",
      "cat file1.txt | jq '.foo[].bar.second | (.key1 | match(\"delimiter1([^*]*)delimter2\").captures[0].string), .key2'",
      "$ jq \\\n  --arg d1 delimiter1 \\\n  --arg d2 delimter2 \\\n  '.foo[].bar.second.key1|gsub(\".*\\($d1)|\\($d2).*\";\"\")'\n\n\"_FIRST_IMPORTANT_VALUE_\"\n\"_SECOND_IMPORTANT_VALUE_\""
    ],
    "utterance": "Extract the substring from each key1 value that lies between delimiter1 and delimter2.",
    "expressions": [
      ".foo[].bar.second | (.key1 | capture(\"delimiter1(?<v>.*)delimter2\").v), .key2",
      ".foo[].bar.second | (.key1 | match(\"delimiter1([^*]*)delimter2\").captures[0].string), .key2",
      ".foo[].bar.second.key1 | gsub(\".*delimiter1|delimter2.*\"; \"\")"
    ],
    "data": [
      {
        "input": {
          "foo": [
            {
              "bar": {
                "second": {
                  "key1": "some/path/to/delimiter1_FIRST_IMPORTANT_VALUE_delimter2",
                  "key2": "OK_as_it_is",
                  "key3": "Just to show there is more stuff"
                }
              }
            },
            {
              "bar": {
                "second": {
                  "key1": "some/path/to/delimiter1_SECOND_IMPORTANT_VALUE_delimter2",
                  "key2": "Also_OK_as_it_is",
                  "key3": "Just to show there is more stuff"
                }
              }
            }
          ]
        },
        "output": [
          "_FIRST_IMPORTANT_VALUE_",
          "_SECOND_IMPORTANT_VALUE_"
        ]
      }
    ],
    "identifier": 78247386,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have a command in my machine named `unescape_html`, a python scipt to unescape the html (replace &amp;#8211; with appropriate character).",
      "How can I apply this function on each of the titles using `jq`.",
      "The point is, i need to run `unescape_html` on `title`, so that i get the expected output.",
      "The following command works:\r\n\r\n    curl -Lfs \"https://motivatedsisters.com/2019/07/08/arabic-review-sr-rahat-basit/\" | rg -o '<li>.*?href=\"(.*?)\".*?</a> (.*?)</li>' -r '{\"url\": \"$1\", \"title\": \"$2\"}' | jq -s '.' | jq 'map(.title |= sub(\"&#8211;\"; \"\u2013\"))'",
      "So, it is applying the bash function. Now I need to format is so that the urls are come with the title in json format.",
      "Both of the following commands are working for me:\r\n\r\n    curl -Lfs \"https://motivatedsisters.com/2019/07/08/arabic-review-sr-rahat-basit/\" | rg -o '<li>.*?href=\"(.*?)\".*?</a> (.*?)</li>' -r 'echo $1 $(unescape_html \"$2\")' | bash | rg -o '(https?://\\S+)\\s(.*)' -r 'echo $1 $(unescape_html \"$2\")'  -r '{\"url\": \"$1\", \"title\": \"$2\"}' | jq -s '.'",
      "and \r\n\r\n    curl -Lfs \"https://motivatedsisters.com/2019/07/08/arabic-review-sr-rahat-basit/\" | rg '<li>.*?href=\"(.*?)\".*?</a> (.*?)</li>' -or '$1 $2' | while read -r link title; do echo \"$link\" \"$(unescape_html \"$title\")\"; done | rg -o '(https?://\\S+)\\s(.*)' -r '{\"url\": \"$1\", \"title\": \"$2\"}' | jq -s '.'"
    ],
    "utterance": "Apply the external command unescape_html to each value of the title key in all objects of the array.",
    "expressions": [
      ".[] | \"unescape_html \\(.title | @sh)\"",
      "map(.title |= sub(\"&#8211;\"; \"\u2013\"))"
    ],
    "data": [
      {
        "input": [
          {
            "url": "https://drive.google.com/file/d/1tO-qVknlH0PLK9CblQsyd568ZiptdKff/view?usp=share_link",
            "title": "&#8211; Flexibility"
          },
          {
            "url": "https://drive.google.com/open?id=11_sR8X13lmPcvlT3POfMW3044f3wZdra",
            "title": "&#8211; Pronouns"
          }
        ],
        "output": [
          {
            "url": "https://drive.google.com/file/d/1tO-qVknlH0PLK9CblQsyd568ZiptdKff/view?usp=share_link",
            "title": "\u2013 Flexibility"
          },
          {
            "url": "https://drive.google.com/open?id=11_sR8X13lmPcvlT3POfMW3044f3wZdra",
            "title": "\u2013 Pronouns"
          }
        ]
      }
    ],
    "identifier": 78252129,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": "The task requires calling an external command (unescape_html) from within jq, which is only possible in jq with the `@sh` or `@csv` filters and using `jq -Rr` with shell command substitution, or with jq's `| system()` in some implementations (like gojq or custom builds). Standard jq does not natively support arbitrary external command invocation. This is an environment-related property."
    }
  },
  {
    "context": [
      "I am trying to get an indexed response/array ([0,...]) to sort - json and/or bash of the values. But my queries are only getting numbers-space separated.",
      "drp=$(cat \"$HOME/directory/file\" | jq '.DailyForecasts[].Day.RainProbability | .')",
      "JSON: -- The query above works as far as returns the correct value/integer output, this is a partial of 5 array sets. Just only returning digits, so: 1 number number number number, not returning in array form.",
      "To convert all values of an array, you need to [`map`](https://jqlang.github.io/jq/manual/#map-map_values) its elements:",
      ".DailyForecasts | map(.Day.RainProbability)",
      "map(f) is equivalent to [.[]|f], so the above can be rewritten to the equivalent:",
      "[.DailyForecasts.[].Day.RainProbability]",
      "Output:",
      "[\n  2,\n  1,\n  7,\n  6,\n  9\n]"
    ],
    "utterance": "Return all Day.RainProbability values for each entry in DailyForecasts as a single indexed array.",
    "expressions": [
      ".DailyForecasts | map(.Day.RainProbability)",
      "[.DailyForecasts[].Day.RainProbability]"
    ],
    "data": [
      {
        "input": {
          "Headline": {
            "EffectiveDate": "2024-04-03T08:00:00-05:00",
            "EffectiveEpochDate": 1712149200,
            "Severity": 7,
            "Text": "Not as hot Wednesday",
            "Category": "cooler",
            "EndDate": "2024-04-03T20:00:00-05:00",
            "EndEpochDate": 1712192400,
            "MobileLink": "http://www.accuweather.com/en/us/mcallen-tx/78501/daily-weather-forecast/335730?lang=en-us",
            "Link": "http://www.accuweather.com/en/us/mcallen-tx/78501/daily-weather-forecast/335730?lang=en-us"
          },
          "DailyForecasts": [
            {
              "Day": {
                "RainProbability": 2
              }
            },
            {
              "Day": {
                "RainProbability": 1
              }
            },
            {
              "Day": {
                "RainProbability": 7
              }
            },
            {
              "Day": {
                "RainProbability": 6
              }
            },
            {
              "Day": {
                "RainProbability": 9
              }
            }
          ]
        },
        "output": [
          2,
          1,
          7,
          6,
          9
        ]
      }
    ],
    "identifier": 78253195,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "parse error: Invalid numeric literal at line 1, column 11",
      "the output of helm show command is below",
      "the helm show chart output can be parsed to json as i need to retrieve the version attribute",
      "jq is a lightweight and flexible command-line *JSON* processor",
      "This means you cannot process generic YAML files with jq, but you need a tool that can handle YAML. One such tool is [yq]",
      "Since it uses a jq like syntax, you can simply swap the command:\n\nhelm show chart \u2026 -n test | yq ."
    ],
    "utterance": "Retrieve the version attribute from helm show chart output containing YAML-formatted chart metadata.",
    "expressions": [
      ".version"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "appVersion": "1.0.0",
          "dependencies": [
            {
              "name": "jaeger",
              "repository": "https://dependencies.vvr.com/artifactory/helm//jaegertracing",
              "version": "0.44.0"
            }
          ],
          "description": "aeger Assembly",
          "name": "jaeger-assembly",
          "version": "1.0.0"
        },
        "output": "1.0.0"
      }
    ],
    "identifier": 78262117,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Now I want to go through and *wherever* I see `\"food\"` object, add a the same key-value pair:",
      "here is how you can do this using the jq command line tool",
      "cat input.json | jq 'walk(if type == \"object\" and has(\"food\") then .food += {\"extra_cheese\": true} else . end)'",
      "Using `walk` would be one way:",
      "walk(select(objects | has(\"food\")).food.extra_cheese = true)",
      "Using `..` would be another:",
      "(.. | objects | select(has(\"food\"))).food.extra_cheese = true"
    ],
    "utterance": "Add the key-value pair \"extra_cheese\": true to every object that has a \"food\" key, at any location and nesting level.",
    "expressions": [
      "walk(if type == \"object\" and has(\"food\") then .food += {\"extra_cheese\": true} else . end)",
      "walk(select(objects | has(\"food\")).food.extra_cheese = true)",
      "(.. | objects | select(has(\"food\"))).food.extra_cheese = true"
    ],
    "data": [
      {
        "input": {
          "lunch": {
            "time": "11 am",
            "food": {
              "is_pizza": true
            }
          },
          "snacks": [
            {
              "time": "2 pm",
              "food": {
                "is_pizza": true
              }
            },
            {
              "time": "3:30 pm",
              "food": {
                "is_pizza": true
              }
            }
          ],
          "dinner": {
            "time": "6 pm",
            "food": {
              "is_pizza": true
            }
          }
        },
        "output": {
          "lunch": {
            "time": "11 am",
            "food": {
              "is_pizza": true,
              "extra_cheese": true
            }
          },
          "snacks": [
            {
              "time": "2 pm",
              "food": {
                "is_pizza": true,
                "extra_cheese": true
              }
            },
            {
              "time": "3:30 pm",
              "food": {
                "is_pizza": true,
                "extra_cheese": true
              }
            }
          ],
          "dinner": {
            "time": "6 pm",
            "food": {
              "is_pizza": true,
              "extra_cheese": true
            }
          }
        }
      }
    ],
    "identifier": 78264525,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "What I need is to get and update values of base_parameters under notebook_task and it's objects project/path using jq utility.",
      "jq '.settings.tasks[].notebook_task.base_parameters' yourfile.json",
      "jq '.settings.tasks[].notebook_task.base_parameters.project = \"app2\"' yourfile.json"
    ],
    "utterance": "Get and update the value of the project field under base_parameters inside notebook_task for all elements in the tasks array where those fields exist.",
    "expressions": [
      ".settings.tasks[].notebook_task.base_parameters",
      ".settings.tasks[].notebook_task.base_parameters.project = \"app2\""
    ],
    "data": [
      {
        "input": {
          "settings": {
            "tasks": [
              {
                "email_notifications": {},
                "job_cluster_key": "artifactory_download_job_cluster",
                "max_retries": 0,
                "min_retry_interval_millis": 900000,
                "notebook_task": {
                  "base_parameters": {
                    "project": "app1",
                    "path": "dir1/source1/file"
                  }
                }
              }
            ]
          }
        },
        "output": [
          {
            "project": "app1",
            "path": "dir1/source1/file"
          }
        ]
      }
    ],
    "identifier": 78265746,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": true
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Within my input JSON data, there are three keys: `page_name`, `page_data`, and `page_url`. I aim to save the content under `page_data` in the `page_content` attribute of LangChain's Document class using jq package. Additionally, I intend to store `page_name` and `page_url` in the metadata.",
      "Final docs should look like this :\n\n    [Document(page_content=\"Content about homepage\", metadata={'source': '/content/json_data.json', 'seq_num': 1, 'page_name': 'Homepage',\"page_url\": \"https://mywebsite.com/homepage\"}),\n     Document(page_content=\"Content about Contact US\", metadata={'source': '/content/json_data.json', 'seq_num': 2,\"page_name\": \"Contact US\",\"page_url\": \"https://mywebsite.com/contactus\"})]",
      "I think the following jq program will generate your desired output format.",
      "to_entries | map({\n    page_content: .value.page_data,\n    metadata: (.value | {\n        source: \"/content/json_data.json\",\n        page_name,\n        page_url\n    } + {seq_num:(.key+1)})\n})",
      "Output:\n\n[\n  {\n    \"page_content\": \"Content about homepage\",\n    \"metadata\": {\n      \"source\": \"/content/json_data.json\",\n      \"page_name\": \"Homepage\",\n      \"page_url\": \"https://mywebsite.com/homepage\",\n      \"seq_num\": 1\n    }\n  },\n  {\n    \"page_content\": \"Content about Contact US\",\n    \"metadata\": {\n      \"source\": \"/content/json_data.json\",\n      \"page_name\": \"Contact US\",\n      \"page_url\": \"https://mywebsite.com/contactus\",\n      \"seq_num\": 1\n    }\n  }\n]"
    ],
    "utterance": "Create an array of objects each with a page_content property set to the value of page_data and a metadata object including source, page_name, page_url, and a sequential number starting from 1.",
    "expressions": [
      "to_entries | map({\n    page_content: .value.page_data,\n    metadata: (.value | {\n        source: \"/content/json_data.json\",\n        page_name,\n        page_url\n    } + {seq_num:(.key+1)})\n})",
      "to_entries | map((.value | {\n    page_content: .page_data,\n    metadata: {\n        source: \"/content/json_data.json\",\n        page_name,\n        page_url\n    }\n}) * { metadata: { seq_num: (.key+1) } })"
    ],
    "data": [
      {
        "input": [
          {
            "_id": {
              "$oid": "65ed5d18b251090135c27d98"
            },
            "page_name": "Homepage",
            "page_data": "Content about homepage",
            "page_url": "https://mywebsite.com/homepage"
          },
          {
            "_id": {
              "$oid": "65ed5d2fb251090135c27d99"
            },
            "page_name": "Contact US",
            "page_data": "Content about Contact US",
            "page_url": "https://mywebsite.com/contactus"
          }
        ],
        "output": [
          {
            "page_content": "Content about homepage",
            "metadata": {
              "source": "/content/json_data.json",
              "page_name": "Homepage",
              "page_url": "https://mywebsite.com/homepage",
              "seq_num": 1
            }
          },
          {
            "page_content": "Content about Contact US",
            "metadata": {
              "source": "/content/json_data.json",
              "page_name": "Contact US",
              "page_url": "https://mywebsite.com/contactus",
              "seq_num": 2
            }
          }
        ]
      }
    ],
    "identifier": 78296361,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "The key of the value to be updated is passed as an argument.",
      "Input",
      "{\n  \"a\": 1,\n  \"b\": 2,\n  \"c\": 3\n}",
      "Expected output with argument: key=b",
      "{\n  \"a\": 1,\n  \"b\": 42,\n  \"c\": 3\n}",
      "jq --arg key b '.[$key] |= (. * 999)' input",
      "jq --arg key b '.[$key] *= 999' input"
    ],
    "utterance": "Update the value of a key, provided as an argument (key=b), to 42.",
    "expressions": [
      ".[$key] = 42"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": 2,
          "c": 3
        },
        "output": {
          "a": 1,
          "b": 42,
          "c": 3
        }
      }
    ],
    "identifier": 78304807,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to get rid of the very first `_rid` but not the ones inside the individual records. My desired output looks like this -",
      "{ \"id\": \"id-1\", \"name\": \"name-1\", \"userId\": \"userid-1\", \"_rid\": \"rid-1\" }",
      "{ \"id\": \"id-2\", \"name\": \"name-2\", \"userId\": \"userid-2\", \"_rid\": \"rid-2\" }",
      "{ \"id\": \"id-3\", \"name\": \"name-3\", \"userId\": \"userid-3\", \"_rid\": \"rid-3\" }",
      "jq -c '.Documents[]' response.json"
    ],
    "utterance": "Output each object from the Documents array as a separate compact line, excluding the root-level properties.",
    "expressions": [
      "jq -c '.Documents[]' response.json"
    ],
    "data": [
      {
        "input": {
          "_rid": "12345",
          "Documents": [
            {
              "id": "id-1",
              "name": "name-1",
              "userId": "userid-1",
              "_rid": "rid-1"
            },
            {
              "id": "id-2",
              "name": "name-2",
              "userId": "userid-2",
              "_rid": "rid-2"
            },
            {
              "id": "id-3",
              "name": "name-3",
              "userId": "userid-3",
              "_rid": "rid-3"
            }
          ],
          "_count": 566
        },
        "output": [
          "{\"id\": \"id-1\", \"name\": \"name-1\", \"userId\": \"userid-1\", \"_rid\": \"rid-1\"}",
          "{\"id\": \"id-2\", \"name\": \"name-2\", \"userId\": \"userid-2\", \"_rid\": \"rid-2\"}",
          "{\"id\": \"id-3\", \"name\": \"name-3\", \"userId\": \"userid-3\", \"_rid\": \"rid-3\"}"
        ]
      }
    ],
    "identifier": 78305924,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I need to use JQ to extract the id values into a new array",
      "I try this:\r\n\r\n`.list[] | .attributes.content[].id`\r\n\r\nthat's my results:\r\n\r\n```\r\n\"AZER\"\r\n\r\n\"WXC\"\r\n\r\n\"QSD\"\r\n```",
      "It's what i want but in 3 line and i need to have it in array\r\nHow can i make this results in an array like this:\r\n\r\n```\r\n[\"AZER\",\"WXC\",\"QSD\"]\r\n```",
      "just wrap you jq query with syntax `[${request}]`\r\n\r\nfor sample \r\n\r\n```\r\njq '[.list[] | .attributes.content[].id]' input.json\r\n```\r\n",
      "In general, just wrap your query that produces a stream of the desired values into array brackets, and the output is an array of those values.\r\n```sh\r\n[.list[] | .attributes.content[].id]\r\n```",
      "Note that there's also a shortcut to `[ .[] \u2026 ]` called `map(\u2026)`:\r\n```sh\r\n.list | map(.attributes.content[].id)\r\n```",
      "Both output:\r\n```json\r\n[\r\n  \"AZER\",\r\n  \"WXC\",\r\n  \"QSD\"\r\n]\r\n```"
    ],
    "utterance": "Extract all id values found in the content arrays under list.*.attributes into a single array.",
    "expressions": [
      "[.list[] | .attributes.content[].id]",
      ".list | map(.attributes.content[].id)",
      "[ .[][].attributes.content[]?.id ]",
      "[ tostream | select((.[0][-1]==\"id\") and (.|length==2)) | .[1] ]"
    ],
    "data": [
      {
        "input": {
          "list": {
            "1": {
              "attributes": {
                "content": [],
                "pageable": {
                  "pageNumber": 0,
                  "pageSize": 10
                }
              }
            },
            "2": {
              "attributes": {
                "content": [
                  {
                    "id": "AZER"
                  }
                ],
                "pageable": {
                  "pageNumber": 0,
                  "pageSize": 10
                }
              }
            },
            "3": {
              "attributes": {
                "content": [
                  {
                    "id": "WXC"
                  },
                  {
                    "id": "QSD"
                  }
                ],
                "pageable": {
                  "pageNumber": 0,
                  "pageSize": 10
                }
              }
            }
          }
        },
        "output": [
          "AZER",
          "WXC",
          "QSD"
        ]
      }
    ],
    "identifier": 78311115,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have this json file for parameters [...] how can I parse this using jq into the following output \n\ncode=ab;env=prod;api=testapi;name=new",
      "Try this:\n``` sh\njq 'map(\"\\(.ParameterKey)=\\(.ParameterValue)\") | join(\";\")'\n```"
    ],
    "utterance": "Produce a semicolon-separated string in the format key=value for each ParameterKey/ParameterValue pair.",
    "expressions": [
      "map(\"\\(.ParameterKey)=\\(.ParameterValue)\") | join(\";\")"
    ],
    "data": [
      {
        "input": [
          {
            "ParameterKey": "code",
            "ParameterValue": "ab"
          },
          {
            "ParameterKey": "env",
            "ParameterValue": "prod"
          },
          {
            "ParameterKey": "api",
            "ParameterValue": "testapi"
          },
          {
            "ParameterKey": "name",
            "ParameterValue": "new"
          }
        ],
        "output": "code=ab;env=prod;api=testapi;name=new"
      }
    ],
    "identifier": 78317715,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have an array of objects that looks like this: ... and I want to add a new key in each of those objects, which will create the URL using the host and path, so I would look like this: ...",
      "I tried doing \".[] |= . { . + {\\\"url\\\": \\\"http://\\\" + .host + .path } }\" but this didn't work ...",
      "Try one of the following filters:\n.[] |= (.url = \"http://\" + .host + .path)",
      "map(.url = \"http://\" + .host + .path)",
      ".[] |= (.url = \"http://\\(.host)\\(.path)\")",
      "map(.url = \"http://\\(.host)\\(.path)\")"
    ],
    "utterance": "For each object in the array, add a new key 'url' whose value is formed by concatenating 'http://', the object's 'host' value, and the object's 'path' value.",
    "expressions": [
      ".[] |= (.url = \"http://\" + .host + .path)",
      "map(.url = \"http://\" + .host + .path)",
      ".[] |= (.url = \"http://\\(.host)\\(.path)\")",
      "map(.url = \"http://\\(.host)\\(.path)\")"
    ],
    "data": [
      {
        "input": [
          {
            "host": "1.exampl.com",
            "path": "/dir1/file.html"
          },
          {
            "host": "2.exampl.com",
            "path": "/dir2/file.html"
          },
          {
            "host": "3.exampl.com",
            "path": "/dir3/file.html"
          }
        ],
        "output": [
          {
            "host": "1.exampl.com",
            "path": "/dir1/file.html",
            "url": "http://1.exampl.com/dir1/file.html"
          },
          {
            "host": "2.exampl.com",
            "path": "/dir2/file.html",
            "url": "http://2.exampl.com/dir2/file.html"
          },
          {
            "host": "3.exampl.com",
            "path": "/dir3/file.html",
            "url": "http://3.exampl.com/dir3/file.html"
          }
        ]
      }
    ],
    "identifier": 78320282,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to select using `jq` all elements that have a `ref` such that there is an element with that `ref` and `key` equal to `42`.",
      "map(select(.key == 42).ref) as $refs | .[] | select(.ref == $refs[])\n# or\nmap(select(.key == 42).ref) as $refs | .[] | select(IN(.ref; $refs[]))",
      "group_by(.ref)[] | select(any(.key == 42))[]"
    ],
    "utterance": "Select all elements whose ref matches a ref value for which there is an element with key equal to 42.",
    "expressions": [
      "map(select(.key == 42).ref) as $refs | .[] | select(.ref == $refs[])",
      "map(select(.key == 42).ref) as $refs | .[] | select(IN(.ref; $refs[]))",
      "group_by(.ref)[] | select(any(.key == 42))[]"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "ref": 32,
            "key": 10
          },
          {
            "id": 2,
            "ref": 32,
            "key": 75
          },
          {
            "id": 3,
            "ref": 27,
            "key": 13
          },
          {
            "id": 4,
            "ref": 27,
            "key": 42
          },
          {
            "id": 5,
            "ref": 438,
            "key": 42
          }
        ],
        "output": [
          {
            "id": 3,
            "ref": 27,
            "key": 13
          },
          {
            "id": 4,
            "ref": 27,
            "key": 42
          },
          {
            "id": 5,
            "ref": 438,
            "key": 42
          }
        ]
      }
    ],
    "identifier": 78325655,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "jq --arg a \"1\" --arg b \"host1.reg.fqdn.com\" '.host_config.\"$b\".config2=$a' sample.json  \ncompletes but does not sub in \"host1.reg.fqdn.com\" for b - it creates new key under .host_config like:   \"$b\": { \"config2\": \"1\" }",
      "To get the key name from the variable value, use the brackets:",
      ".host_config[$b].config2",
      ".host_config[$b].config2 = $a"
    ],
    "utterance": "Set the value of config2 for a host with a dotted hostname using variables for the hostname and new value.",
    "expressions": [
      ".host_config[$b].config2 = $a"
    ],
    "data": [
      {
        "input": {
          "host_config": {
            "host1.reg.fqdn.com": {
              "config1": "AAA",
              "config2": "000"
            },
            "host2.reg.fqdn.com": {
              "config1": "BBB",
              "config2": "000"
            },
            "host3.reg.fqdn.com": {
              "config1": "CCC",
              "config2": "000"
            }
          }
        },
        "output": {
          "host_config": {
            "host1.reg.fqdn.com": {
              "config1": "AAA",
              "config2": "1"
            },
            "host2.reg.fqdn.com": {
              "config1": "BBB",
              "config2": "000"
            },
            "host3.reg.fqdn.com": {
              "config1": "CCC",
              "config2": "000"
            }
          }
        }
      }
    ],
    "identifier": 78330476,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Here is my first input (recorded as bash var $services)",
      "I\u2019d like to use **subPath** to update deployment.json.",
      "jq --argjson services \"$services\" '\n   .|=\n    (\n      .metadata.name as $name |\n         | .spec.template.spec.containers[]?.volumeMounts[]? \n      . += { subPath: ($services[] | select(.key == $name).subPath // .subPath) }\n    )\n' deployment.json > updated_deployment.json",
      "When multiple entries in $services have the same key and you want to handle all corresponding subPath values. You could transform the $services input to group them by key, and then iterate over these groups when updating the JSON",
      "jq --argjson services \"$grouped_services\" '\n  .spec.template.spec.containers[].volumeMounts[] |=\n    (\n      .name as $name |\n      . + { mountPath: ($services[] | select(.key == $name).subPaths[] // .mountPath) }\n    )\n' deployment.json > updated_deployment.json"
    ],
    "utterance": "Update the subPath of each volumeMount in deployment data by matching its name with the key in services data, using the corresponding subPath value(s) from services.",
    "expressions": [
      "jq --argjson services \"$services\" '\n   .spec.template.spec.containers[].volumeMounts[]? |=\n     (.name as $name | . + { subPath: ($services[] | select(.key == $name).subPath // .subPath) })\n' deployment.json",
      "jq --argjson services \"$grouped_services\" '\n  .spec.template.spec.containers[].volumeMounts[] |=\n    (\n      .name as $name |\n      . + { mountPath: ($services[] | select(.key == $name).subPaths[] // .mountPath) }\n    )\n' deployment.json"
    ],
    "data": [
      {
        "input": [
          {
            "key": "movies-wikibase-jobrunner",
            "subPath": "LocalSettings.php",
            "cm": "movies-wikibase-jobrunner-localsettings-override-php"
          },
          {
            "key": "movies-wikibase-jobrunner",
            "subPath": "jobrunner-entrypoint.sh",
            "cm": "movies-wikibase-jobrunner-jobrunner-entrypoint-sh"
          },
          {
            "key": "movies-wikibase-wdqs-frontend",
            "subPath": "wdqs_front_index.html",
            "cm": "movies-wikibase-wdqs-frontend-index-html"
          }
        ]
      },
      {
        "input": {
          "spec": {
            "template": {
              "spec": {
                "containers": [
                  {
                    "volumeMounts": [
                      {
                        "mountPath": "/usr/share/nginx/html/index.html",
                        "name": "movies-wikibase-wdqs-frontend-index-html",
                        "subPath": "wdqs_front_index.html"
                      }
                    ]
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 78337654,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": true
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "basically I want to create a new json file where everything from \"east\" key of common.json + \"common\" key of common.json + the \"common\" key of pi.json + the \"east\" key of pi.json are moved to one json file.",
      "The output I wanted for test.json is: \n{\n  \"MyUri\": \"www.myuri.com\",\n  \"App-Env\": 1713311902,\n  \"SentinelValue\": 1713311902,\n  \"Hello\": \"ABC\",\n  \"Direction\": \"East\"\n}",
      "just address them after `--slurp`ing them into an array by using `first` and `last` (or `.[0]` and `.[1]`):\n```sh\njq -s 'first.east + first.common + last.common + last.east'\n```",
      "Alternatively, consider using `input` to access the second input (note that there's no need to `--slurp` with `input`):\n```sh\njq '.east + .common + (input | .common + .east)'\n```"
    ],
    "utterance": "Combine the objects under the keys 'east' and 'common' from two files so that the output contains all key-value pairs from 'common.east', 'common.common', 'pi.common', and 'pi.east', merged into a single object.",
    "expressions": [
      "jq -s 'first.east + first.common + last.common + last.east' common.json pi.json",
      "jq '.east + .common + (input | .common + .east)' common.json pi.json"
    ],
    "data": [
      {
        "input": {
          "common.json": {
            "common": {
              "Hello": "ABC"
            },
            "east": {
              "Direction": "East"
            },
            "west": {
              "Direction": "West"
            }
          },
          "pi.json": {
            "common": {
              "MyUri": "www.myuri.com"
            },
            "east": {
              "App-Env": "my-pi",
              "SentinelValue": 1713311902
            },
            "west": {
              "App-Env": "my-piw",
              "SentinelValue": 1713311902
            }
          }
        },
        "output": {
          "MyUri": "www.myuri.com",
          "App-Env": "my-pi",
          "SentinelValue": 1713311902,
          "Hello": "ABC",
          "Direction": "East"
        }
      }
    ],
    "identifier": 78337845,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": true,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I would like to see only the content for `if`, `pcp` or `proto`, which have `selected ==1`. Whether I get their key or their value is anther problem.",
      "Traverse to each potential object, e.g. using `.[].value[\"if\", \"pcp\", \"proto\"]`, and update its items using either `map_values` or another level of iteration (reliable since jq 1.7) by filtering for their items that match the condition, `.selected == 1` in this case:",
      ".[].value[\"if\", \"pcp\", \"proto\"] |= map_values(select(.selected == 1))"
    ],
    "utterance": "Filter the 'if', 'pcp', and 'proto' attributes in each item so that only the sub-objects where 'selected' equals 1 are kept.",
    "expressions": [
      ".[].value[\"if\", \"pcp\", \"proto\"] |= map_values(select(.selected == 1))",
      ".[].value[\"if\", \"pcp\", \"proto\"][] |= select(.selected == 1)"
    ],
    "data": [
      {
        "input": [
          {
            "key": "0eb660b0-555a-469e-be04-8c3584108f9b",
            "value": {
              "if": {
                "igb1": {
                  "value": "igb1 (64:62:66:22:6e:d0) [UNTAGGED]",
                  "selected": 0
                },
                "igb2": {
                  "value": "igb2 (64:62:66:22:6e:d1) [tagged]",
                  "selected": 1
                }
              },
              "tag": "20",
              "pcp": {
                "1": {
                  "value": "Background (1, lowest)",
                  "selected": 0
                },
                "0": {
                  "value": "Best Effort (0, default)",
                  "selected": 1
                },
                "2": {
                  "value": "Excellent Effort (2)",
                  "selected": 0
                }
              },
              "proto": {
                "": {
                  "value": "Auto",
                  "selected": 1
                },
                "802.1q": {
                  "value": "802.1Q",
                  "selected": 0
                },
                "802.1ad": {
                  "value": "802.1ad",
                  "selected": 0
                }
              },
              "descr": "USERS: PCs und Handies  ",
              "vlanif": "vlan0.20"
            }
          }
        ],
        "output": [
          {
            "key": "0eb660b0-555a-469e-be04-8c3584108f9b",
            "value": {
              "if": {
                "igb2": {
                  "value": "igb2 (64:62:66:22:6e:d1) [tagged]",
                  "selected": 1
                }
              },
              "tag": "20",
              "pcp": {
                "0": {
                  "value": "Best Effort (0, default)",
                  "selected": 1
                }
              },
              "proto": {
                "": {
                  "value": "Auto",
                  "selected": 1
                }
              },
              "descr": "USERS: PCs und Handies  ",
              "vlanif": "vlan0.20"
            }
          }
        ]
      }
    ],
    "identifier": 78340421,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "converting json objects to bash variable",
      "declare $(echo $json | jq -r 'to_entries | .[] | \"export \\(.key)=\\(.value)\"')",
      "For description it is only printing `nphies-support-service` instead of `nphies-support-service Spring Boot Application`. Looks like it is breaking on first space.",
      "But when I read the same field using the syntax `name=$(echo $json | jq -r '.description')` it prints the whole text."
    ],
    "utterance": "Convert all key-value pairs in the data into shell variables in such a way that values containing spaces are preserved fully.",
    "expressions": [
      "jq -r 'to_entries | .[] | \"export \\(.key)=\\\"\\(.value)\\\"\"'"
    ],
    "data": [
      {
        "input": {
          "service_name": "nphies-support.service",
          "description": "nphies-support-service Spring Boot Application",
          "user": "aceusr",
          "working_directory": "/home/aceusr/deployment/nphies/nphies-support",
          "java_home": "/usr/lib/jvm/jdk-21.0.1",
          "jar_file": "nphies-support-service.jar"
        },
        "output": [
          "export service_name=\"nphies-support.service\"",
          "export description=\"nphies-support-service Spring Boot Application\"",
          "export user=\"aceusr\"",
          "export working_directory=\"/home/aceusr/deployment/nphies/nphies-support\"",
          "export java_home=\"/usr/lib/jvm/jdk-21.0.1\"",
          "export jar_file=\"nphies-support-service.jar\""
        ]
      }
    ],
    "identifier": 78342087,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "What I really want to achieve is to remove these keys:\n\n.alternate_error_pages\n.autocomplete\n.browser.app_window_placement.DevToolsApp",
      "Use `del(.key1, .key2, .key3)` as the filter",
      "> jq-windows-amd64.exe \"del(.alternate_error_pages, .autocomplete, .browser.app_window_placement.DevToolsApp)\" json"
    ],
    "utterance": "Remove the keys alternate_error_pages, autocomplete, and browser.app_window_placement.DevToolsApp from the data.",
    "expressions": [
      "del(.alternate_error_pages, .autocomplete, .browser.app_window_placement.DevToolsApp)"
    ],
    "data": [
      {
        "input": {
          "account_tracker_service_last_update": "13351819478658924",
          "alternate_error_pages": {
            "backup": true,
            "enabled": false
          },
          "announcement_notification_service_first_run_time": "13272713839385778",
          "autocomplete": {
            "retention_policy_last_version": 120
          },
          "browser": {
            "app_window_placement": {
              "DevToolsApp": {
                "always_on_top": false,
                "work_area_top": 0
              }
            },
            "clear_data": {
              "time_period": 4
            },
            "last_clear_browsing_data_tab": 1
          }
        },
        "output": {
          "account_tracker_service_last_update": "13351819478658924",
          "announcement_notification_service_first_run_time": "13272713839385778",
          "browser": {
            "app_window_placement": {},
            "clear_data": {
              "time_period": 4
            },
            "last_clear_browsing_data_tab": 1
          }
        }
      }
    ],
    "identifier": 78343435,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Given the the sample json\n\n    [\n      {\n        \"firstName\": \"Doug\",\n        \"accountNumber\": \"123456\",\n        \"language\": \"en_US\",\n        \"brand\": \"Tide\",\n        \"country\": \"US\",\n        \"branch\": \"MIA\",\n        \"city\": \"Miami\",\n        \"state\": \"FL\",\n        \"zipCode\": \"33133\"\n      }\n    ]",
      "I am unable to perform any of the more complex actions such as extracting specific attributes ...\n\n    .[] | {accountNumber:.accountNumber, brand:.brand, city:.city, state:.state}",
      "jq '.[]|{accountNumber,brand,city,state}' sample.json\n# is the same as\njq 'map({accountNumber,brand,city,state})[]' sample.json",
      "`jq \".[] | select(.city == \\\"Miami\\\") | {accountNumber, brand, city, state}\" sample.json`",
      "`jq 'map({accountNumber,brand,city,state})[] | select(.city == \"Miami\")' sample.json`"
    ],
    "utterance": "Select objects where city is Miami and output only accountNumber, brand, city, and state fields.",
    "expressions": [
      ".[] | select(.city == \"Miami\") | {accountNumber, brand, city, state}",
      "map({accountNumber,brand,city,state})[] | select(.city == \"Miami\")"
    ],
    "data": [
      {
        "input": [
          {
            "firstName": "Doug",
            "accountNumber": "123456",
            "language": "en_US",
            "brand": "Tide",
            "country": "US",
            "branch": "MIA",
            "city": "Miami",
            "state": "FL",
            "zipCode": "33133"
          }
        ],
        "output": {
          "accountNumber": "123456",
          "brand": "Tide",
          "city": "Miami",
          "state": "FL"
        }
      }
    ],
    "identifier": 78344013,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I need a filter, that changes \"value\" to \"OK\" of the parent (\"id\": \"100\"), when every _child_ in \"sub\" with \"input\" value \"Text\" has no empty \"value\" and every \"input\" value \"ChecklistState\" has value \"OK\". ( -> 110 not empty, 120, 130 and 140 \"OK\")",
      "Please note: due to software requirements, I need to use jq v1.5",
      "if .sub | map(.key = .id) | from_entries                  # create an index\n    | [.\"110\" != \"OK\", .[\"120\",\"130\",\"140\"] == \"OK\"] | all  # match condition\n  then .value = \"OK\"",
      "if .sub | all(\n    .input == \"Text\" and .value != \"\" or\n    .input == \"ChecklistState\" and .value == \"OK\"\n  )\n  then .value = \"OK\""
    ],
    "utterance": "Set the parent's value to OK if all children with input type Text have a non-empty value and all children with input type ChecklistState have value OK.",
    "expressions": [
      "map(\n  if .sub | all(\n    (.input == \"Text\" and .value != \"\") or\n    (.input == \"ChecklistState\" and .value == \"OK\")\n  )\n  then .value = \"OK\"\n  else .\n  end\n)",
      "map(\n  if .sub | map(.key = .id) | from_entries \n    | [.[\"110\"].value != \"\", (.[\"120\"].value == \"OK\" and .[\"130\"].value == \"OK\" and .[\"140\"].value == \"OK\")] | all\n  then .value = \"OK\"\n  else .\n  end\n)"
    ],
    "data": [
      {
        "input": [
          {
            "id": "100",
            "input": "ChecklistState",
            "value": "-",
            "sub": [
              {
                "id": "110",
                "input": "Text",
                "value": "foo",
                "sub": []
              },
              {
                "id": "120",
                "input": "ChecklistState",
                "value": "OK",
                "sub": []
              },
              {
                "id": "130",
                "input": "ChecklistState",
                "value": "OK",
                "sub": []
              },
              {
                "id": "140",
                "input": "ChecklistState",
                "value": "OK",
                "sub": []
              }
            ]
          }
        ],
        "output": [
          {
            "id": "100",
            "input": "ChecklistState",
            "value": "OK",
            "sub": [
              {
                "id": "110",
                "input": "Text",
                "value": "foo",
                "sub": []
              },
              {
                "id": "120",
                "input": "ChecklistState",
                "value": "OK",
                "sub": []
              },
              {
                "id": "130",
                "input": "ChecklistState",
                "value": "OK",
                "sub": []
              },
              {
                "id": "140",
                "input": "ChecklistState",
                "value": "OK",
                "sub": []
              }
            ]
          }
        ]
      }
    ],
    "identifier": 78366187,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "When I retrieve matches for locations of New York and Los Angeles..\r\n\r\n    jq \".[] | select((.location == \\\"New York\\\") or select(.location == \\\"Los Angeles\\\"))\" sample.json\r\n\r\nI see the output:\r\n\r\n    {\r\n      \"name\": \"Bob\",\r\n      \"location\": \"New York\"\r\n    }\r\n    {\r\n      \"name\": \"Adam\",\r\n      \"location\": \"Los Angeles\"\r\n    }",
      "So I need a fix in order to see the expected look below without physically changing the original sample.json file:\r\n\r\n    {\r\n      \"name\": \"Bob\",\r\n      \"location\": \"New York\"\r\n    },\r\n    {\r\n      \"name\": \"Adam\",\r\n      \"location\": \"Los Angeles\"\r\n    }\r\n\r\nor even this if it's possible\r\n\r\n    [\r\n      {\r\n          \"name\": \"Bob\",\r\n          \"location\": \"New York\"\r\n      },\r\n      {\r\n          \"name\": \"Adam\",\r\n          \"location\": \"Los Angeles\"\r\n      }\r\n    ]",
      "If you want to return an array, use map(f) to apply the filter f to every element in the array. map(f) is equivalent to [.[] | f] (and in fact [implemented as such](https://github.com/jqlang/jq/blob/e4d0b12d7d5b91e6bb1d2d233018bc63ed28e3ae/src/builtin.jq#L3)).",
      "map(select(.location == \"New York\" or .location == \"Los Angeles\"))"
    ],
    "utterance": "Return all objects whose location is New York or Los Angeles as an array.",
    "expressions": [
      "map(select(.location == \"New York\" or .location == \"Los Angeles\"))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Bob",
            "location": "New York"
          },
          {
            "name": "Adam",
            "location": "Los Angeles"
          },
          {
            "name": "Jill",
            "location": "Chicago"
          }
        ],
        "output": [
          {
            "name": "Bob",
            "location": "New York"
          },
          {
            "name": "Adam",
            "location": "Los Angeles"
          }
        ]
      }
    ],
    "identifier": 78368160,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to filter this file to only output content where a given pattern appears in anywhere in the full path or leaf node value.",
      "And the pattern is \"foo\". Then, the output should be as follows.",
      "This formulation has the advantage that you can easily specify similar alternatives, e.g. ... prune(test\"foo\"))",
      "jq --stream -n < file.json '\n    fromstream(\n        inputs | select(\n            (length == 1)\n            or any(\n                (.[0][], .[1]) | strings;\n                test(\"foo\")\n            )\n        )\n    )\n'",
      "def prune(cond):\n  def prune_object: \n    . as $in \n    | reduce keys_unsorted[] as $k ({};   # preserve ordering\n        if ($k|cond) then .[$k] = $in[$k]\n        else [$in[$k] | prune(cond)] as $x\n        | if $x == [] then .\n          else .[$k] = $x[0]\n          end\n        end )\n    | select(. != {});\n  if type == \"object\" then prune_object\n  elif type == \"array\" \n  then map(prune(cond))\n  | select(. != [])\n  elif type == \"string\" then select(cond)\n  else empty\n  end;\n\nprune(test\"foo\"))",
      "Here is a way:\ndef f:\n  def g:\n    def h: type == \"string\" and test(\"foo\") | not;\n    del(getpath(\n      paths(scalars, select(IN([], {}))) | select(all(h))\n    ) | select(h));\n  . as $in | g | if . != $in then f end;\nf"
    ],
    "utterance": "Keep only the parts of the data where the string \"foo\" appears in any key along the path or as a leaf value.",
    "expressions": [
      "def prune(cond):\n  def prune_object: \n    . as $in \n    | reduce keys_unsorted[] as $k ({};\n        if ($k|cond) then .[$k] = $in[$k]\n        else [$in[$k] | prune(cond)] as $x\n        | if $x == [] then .\n          else .[$k] = $x[0]\n          end\n        end )\n    | select(. != {});\n  if type == \"object\" then prune_object\n  elif type == \"array\" then map(prune(cond)) | select(. != [])\n  elif type == \"string\" then select(cond)\n  else empty\n  end;\n\nprune(test\"foo\")",
      "jq --stream -n < file.json '\n    fromstream(\n        inputs | select(\n            (length == 1)\n            or any(\n                (.[0][], .[1]) | strings;\n                test(\"foo\")\n            )\n        )\n    )\n'",
      "def f:\n  def g:\n    def h: type == \"string\" and test(\"foo\") | not;\n    del(getpath(\n      paths(scalars, select(IN([], {}))) | select(all(h))\n    ) | select(h));\n  . as $in | g | if . != $in then f end;\nf"
    ],
    "data": [
      {
        "input": {
          "a": "foo",
          "b": "bar",
          "c": {
            "d": "foo",
            "e": "bar"
          },
          "aa": {
            "foo": [
              1,
              2,
              3
            ],
            "bar": {
              "foo": false
            },
            "delete-this": {
              "not": "wanted"
            }
          },
          "delete-all": {
            "x": {
              "a": {
                "b": {
                  "c": 1
                }
              }
            },
            "y": {
              "a": [
                {
                  "b": [
                    1
                  ]
                }
              ]
            }
          },
          "keep-part": [
            "foo",
            "bar"
          ]
        },
        "output": {
          "a": "foo",
          "c": {
            "d": "foo"
          },
          "aa": {
            "foo": [
              1,
              2,
              3
            ],
            "bar": {
              "foo": false
            }
          },
          "keep-part": [
            "foo"
          ]
        }
      }
    ],
    "identifier": 78368831,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Suppose I have a json object like this\n\n        {\n      \"name\": \"abc\",\n      \"version\": \"1234\"\n    }\n    {\n      \"name\": \"xyz\",\n      \"version\": \"6789\"\n    }\n\nI want it to transform it to \n\n    {\n    \"abc\": \"1234\",\n    \"xyz\" : \"6789\"\n    }\n\nI have tried map and reduce. But cant wrap my head around",
      "One way would be to `reduce` over all `inputs`, and successively build up the result object. Use the `--null-input` (or `-n`) flag for that:\n```sh\njq -n 'reduce inputs as $i ({}; .[$i.name] = $i.version)'\n```",
      "Another one would be to create a `map` of objects for each item, then `add` them all together into a result object. Use the `--slurp` (or `-s`) flag for that:\n```sh\njq -s 'map({(.name): .version}) | add'\n```",
      "Output:\n```json\n{\n  \"abc\": \"1234\",\n  \"xyz\": \"6789\"\n}\n```"
    ],
    "utterance": "Convert an array of objects with properties 'name' and 'version' into a single object mapping each name to its corresponding version.",
    "expressions": [
      "reduce inputs as $i ({}; .[$i.name] = $i.version)",
      "map({(.name): .version}) | add"
    ],
    "data": [
      {
        "input": [
          {
            "name": "abc",
            "version": "1234"
          },
          {
            "name": "xyz",
            "version": "6789"
          }
        ],
        "output": {
          "abc": "1234",
          "xyz": "6789"
        }
      }
    ],
    "identifier": 78374396,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to iterate through the array of objects in `o.json` and compute the difference between two values (`.cpus.total - .cpus.allocated`) and display the sum of those deltas as well as the sum of one of the values (`.cpus.total`).",
      "So `.[].cpus.total` will spit out a list of integers:",
      "$ cat /tmp/o.json | jq -c '[.[].cpus.total]|add'",
      "But when I do the same thing after a map statement, it errors:",
      "$ cat /tmp/o.json | jq -c '[(map(.cpus.total - .cpus.allocated) | add), \"/\", [.[].cpus.total]|add]'",
      "jq: error (at <stdin>:13762): Cannot iterate over number (2556)",
      "And sure enough, forcing it into an array (and then taking the zero'th value, because it is just an integer) works:",
      "$ cat /tmp/o.json | jq -c '[(map(.cpus.total - .cpus.allocated) | add), \"/\", [[.[].cpus.total]|add][0] ]'",
      "[2556,\"/\",2764]"
    ],
    "utterance": "Compute the sum of differences between .cpus.total and .cpus.allocated for each object and the sum of .cpus.total, then output them as an array with a slash between.",
    "expressions": [
      "[(map(.cpus.total - .cpus.allocated) | add), \"/\", [[.[].cpus.total]|add][0]]"
    ],
    "data": [
      {
        "input": [
          {
            "cpus": {
              "total": 10,
              "allocated": 5
            }
          },
          {
            "cpus": {
              "total": 20,
              "allocated": 15
            }
          }
        ],
        "output": [
          10,
          "/",
          30
        ]
      }
    ],
    "identifier": 78379111,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "When I run\n\n    jq --arg md \"blablabla\" '. +={'content': \"$md\"}' blog.json",
      "I get\n\n    {\n      \"foo\": \"bar\",\n      \"content\": \"$md\"\n    }",
      "The **desired** output would be:\n\n    {\n      \"foo\": \"bar\",\n      \"content\": \"blablabla\"\n    }",
      "Access the variable directly without quotes",
      "jq --arg md \"blablabla\" '. + {\"content\": $md}' blog.json"
    ],
    "utterance": "Add a key named content with value blablabla using a command-line argument, so the value is inserted, not the literal variable name.",
    "expressions": [
      ". + {\"content\": $md}"
    ],
    "data": [
      {
        "input": {
          "foo": "bar"
        },
        "output": {
          "foo": "bar",
          "content": "blablabla"
        }
      }
    ],
    "identifier": 78381387,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "how can I make sure that it raises an error if `slot` key is not found? What I mean is that in both last two examples the exit code is 0",
      "If you're using jq 1.6 you need this:\n``` sh\njq -nre 'inputs.slot'\n```"
    ],
    "utterance": "Fail with a nonzero exit code if the slot key is missing from the input",
    "expressions": [
      "jq -nre 'inputs.slot'"
    ],
    "data": [
      {
        "input": " ",
        "output": null
      },
      {
        "input": "",
        "output": null
      }
    ],
    "identifier": 78383239,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": true
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to copy the value of `.name` to the value of `.value` for each entry in `items[]`.",
      "How can I make the change within the entries, for each entry, but still output the whole thing from the top level?",
      ".items[] |= (.value = .name)",
      ".items |= map(.value = .name)"
    ],
    "utterance": "For each element in items, set value equal to name, keeping the overall structure.",
    "expressions": [
      ".items[] |= (.value = .name)",
      ".items |= map(.value = .name)"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "name": "first"
            },
            {
              "name": "second"
            }
          ]
        },
        "output": {
          "items": [
            {
              "name": "first",
              "value": "first"
            },
            {
              "name": "second",
              "value": "second"
            }
          ]
        }
      }
    ],
    "identifier": 78391549,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "curl -X GET \"http://localhost:8080/test\" ^| jq -r \".integrations.[0].id\"",
      "jq -r \".integrations.[0].id\""
    ],
    "utterance": "Extract the id field of the first element in the integrations array from the fetched data.",
    "expressions": [
      ".integrations[0].id",
      ".integrations.[0].id"
    ],
    "identifier": 78393001,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I would like to search it recursively where `val2` equals `bar1` but return it in this format:",
      "This produces your expected output:",
      "map_values(map(select(.val2 == \"bar1\")))"
    ],
    "utterance": "Filter all objects inside every field to include only those where val2 equals bar1, preserving the top-level keys.",
    "expressions": [
      "map_values(map(select(.val2 == \"bar1\")))"
    ],
    "data": [
      {
        "input": {
          "source_1": [
            {
              "val1": "foo1",
              "val2": "bar1"
            },
            {
              "val1": "foo2",
              "val2": "bar2"
            }
          ],
          "source_2": [
            {
              "val1": "foo1",
              "val2": "bar1"
            },
            {
              "val1": "foo3",
              "val2": "bar3"
            }
          ]
        },
        "output": {
          "source_1": [
            {
              "val1": "foo1",
              "val2": "bar1"
            }
          ],
          "source_2": [
            {
              "val1": "foo1",
              "val2": "bar1"
            }
          ]
        }
      }
    ],
    "identifier": 78397008,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I need to turn this into something more readable, ideally, I'd like it to look like this (the following is valid JSON, but I'm not fussy if it is not strictly accurate - the general format is the important thing)",
      "It seems I need to process the fvAp array in a similar way, but I've not had any success isolating the array to process it.",
      "Finally got it figured, thanks to @knittl the suggestions and example using **map**. Using the following, I was able to get very close to my target output.",
      "```\n.imdata\n| map(.fvTenant | {\n  fvTenant: .attributes.name,\n  fvAp: (.children\n    | map(.fvAp |{\n      fvAp: .attributes.name,\n      fvAEPg: (.children | map(.fvAEPg |{\n        fvAEPg: .attributes.name,\n        fvRsCons: ([.children[].fvRsCons.attributes.tnVzBrCPName | values] ),\n        fvRsProv: ([.children[].fvRsProv.attributes.tnVzBrCPName | values] )\n      }))\n    })\n  )\n})\n```"
    ],
    "utterance": "Transform a nested data structure to an array where each entry lists the tenant name, applications, endpoint groups, with consumer and provider contract names as arrays under each endpoint group.",
    "expressions": [
      ".imdata | map(.fvTenant | { fvTenant: .attributes.name, fvAp: (.children | map(.fvAp |{ fvAp: .attributes.name, fvAEPg: (.children | map(.fvAEPg |{ fvAEPg: .attributes.name, fvRsCons: ([.children[].fvRsCons.attributes.tnVzBrCPName | values] ), fvRsProv: ([.children[].fvRsProv.attributes.tnVzBrCPName | values] ) })) })) ) })"
    ],
    "data": [
      {
        "input": {
          "totalCount": "3",
          "imdata": [
            {
              "fvTenant": {
                "attributes": {
                  "dn": "uni/tn-Tenant10",
                  "name": "Tenant10"
                },
                "children": [
                  {
                    "fvAp": {
                      "attributes": {
                        "name": "2Tier_AP"
                      },
                      "children": [
                        {
                          "fvAEPg": {
                            "attributes": {
                              "name": "WebServers_EPG"
                            },
                            "children": [
                              {
                                "fvRsCons": {
                                  "attributes": {
                                    "tnVzBrCPName": "AppServices_Ct"
                                  },
                                  "children": [
                                    {
                                      "fvCollectionCont": {
                                        "attributes": {
                                          "collectionDn": "uni/tn-common/brc-AppServices_Ct",
                                          "name": "",
                                          "nameAlias": ""
                                        }
                                      }
                                    }
                                  ]
                                }
                              }
                            ]
                          }
                        },
                        {
                          "fvAEPg": {
                            "attributes": {
                              "name": "AppServers_EPG"
                            },
                            "children": [
                              {
                                "fvRsProv": {
                                  "attributes": {
                                    "tnVzBrCPName": "AppServices_Ct"
                                  },
                                  "children": [
                                    {
                                      "fvCollectionCont": {
                                        "attributes": {
                                          "collectionDn": "uni/tn-common/brc-AppServices_Ct",
                                          "name": "",
                                          "nameAlias": ""
                                        }
                                      }
                                    }
                                  ]
                                }
                              }
                            ]
                          }
                        }
                      ]
                    }
                  }
                ]
              }
            }
          ]
        },
        "output": [
          {
            "fvTenant": "Tenant10",
            "fvAp": [
              {
                "2Tier_AP": {
                  "fvAEPg": [
                    {
                      "WebServers_EPG": {
                        "fvRsCons": [
                          "AppServices_Ct"
                        ],
                        "fvRsProv": []
                      }
                    },
                    {
                      "AppServers_EPG": {
                        "fvRsCons": [],
                        "fvRsProv": [
                          "AppServices_Ct"
                        ]
                      }
                    }
                  ]
                }
              }
            ]
          }
        ]
      }
    ],
    "identifier": 78401284,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I am trying to get only the \"cpu\" for the \"mysql\" container, but I keep getting both \"sidecar, and mysql\".",
      "I keep getting the following but should ONLY see \"2100m\":\n\n    null\n    2100m",
      "After you `selected` the correct name, you'll need to continue `select`'ing on the `.spec.containers` to find the one with `name === \"mysql\"` and then select the `.resources.limits.cpu` from that object:",
      "```\n.items[] | select(.metadata.name == $_NAME) | (.spec.containers[] | select(.name == \"mysql\").resources?.limits?.cpu)\n```",
      "Will output:\n```none\n\"2100m\"\n```"
    ],
    "utterance": "Retrieve the cpu limit value only for the container named mysql within the item whose metadata.name matches a specific value.",
    "expressions": [
      ".items[] | select(.metadata.name == $_NAME) | (.spec.containers[] | select(.name == \"mysql\").resources?.limits?.cpu)"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "items": [
            {
              "apiVersion": "v1",
              "kind": "Pod",
              "metadata": {
                "name": "mysql-innodb-cluster-0"
              },
              "spec": {
                "containers": [
                  {
                    "name": "sidecar",
                    "resources": {}
                  },
                  {
                    "name": "mysql",
                    "resources": {
                      "limits": {
                        "cpu": "2100m",
                        "memory": "5G"
                      }
                    }
                  }
                ]
              }
            }
          ],
          "kind": "List"
        },
        "output": "2100m"
      }
    ],
    "identifier": 78403902,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "If you omit the trailing comma in the initial production, you get a stream of inputs that jq can collect into an array using the `--slurp` (or `-s`) flag:",
      "for k in \"${!mymap[@]}\"; do \n  opt=\"{\\\"OptionName\\\":\\\"${k}\\\", \\\"Value\\\":\\\"${mymap[$k]}\\\"}\"\n  echo \"$opt\"                            # no comma here --^\ndone | jq -s . > option.json",
      "However, you can also have jq do the JSON composition in the first place, guaranteeing valid JSON encoding even with challenging values (such as double quotes, etc.). For example, I'd use the `--args` option to import the bash array's keys and values as positional parameters, and the `$ARGS` builtin to access them:",
      "jq -n '\n  $ARGS.positional | [_nwise(length/2)] | transpose\n  | map({OptionName: first, Value: last})\n' --args \"${!mymap[@]}\" \"${mymap[@]}\" > option.json",
      "jq -n '$ARGS.positional | [_nwise(2) | {OptionName: first, Value: last}]' \\\n  --args \"${mymap[@]@k}\""
    ],
    "utterance": "Create an array where each element is an object with OptionName and Value keys from two Bash arrays containing keys and values.",
    "expressions": [
      ".",
      "$ARGS.positional | [_nwise(2) | {OptionName: first, Value: last}]"
    ],
    "data": [
      {
        "input": [
          {
            "OptionName": "name",
            "Value": "test"
          },
          {
            "OptionName": "age",
            "Value": "13"
          }
        ],
        "output": [
          {
            "OptionName": "name",
            "Value": "test"
          },
          {
            "OptionName": "age",
            "Value": "13"
          }
        ]
      }
    ],
    "identifier": 78411838,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": true
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Suppose I have this ndjson:",
      "{ \"id\": \"one\", \"colors\": [{\"color\": \"blue\"}, {\"color\": \"red\"}]}",
      "{ \"id\": \"two\", \"colors\": [{\"color\": \"green\"}]}",
      "How do I get the output below?",
      "one blue",
      "one red",
      "two green",
      "The most direct approach:",
      "jq -r '.id + \" \" + .colors[].color' my.ndjson",
      "Since you mentioned @tsv, and since @tsv output has various potential advantages, you may also wish to consider:",
      ".id as $id | .colors[] | [$id, .color] | @tsv",
      "Or, as @oguz_ismail suggested, if you don't want to use as at all:",
      "[.id]+(.colors[]|[.color])|@tsv",
      "The combinations function outputs all combinations of input elements. This will pair every id with every color:",
      "$ jq -r '[[.id], [.colors[].color]] | combinations | join(\" \")' test.json"
    ],
    "utterance": "Output each object's id paired with each color value, on its own line, with id and color separated by a space.",
    "expressions": [
      ".id + \" \" + .colors[].color",
      ".id as $id | .colors[] | [$id, .color] | @tsv",
      "[.id]+(.colors[]|[.color])|@tsv",
      "[[.id], [.colors[].color]] | combinations | join(\" \")"
    ],
    "data": [
      {
        "input": [
          {
            "id": "one",
            "colors": [
              {
                "color": "blue"
              },
              {
                "color": "red"
              }
            ]
          },
          {
            "id": "two",
            "colors": [
              {
                "color": "green"
              }
            ]
          }
        ],
        "output": [
          "one blue",
          "one red",
          "two green"
        ]
      }
    ],
    "identifier": 78415979,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "However, when I echo $NETWORK_INTERFACE the output will missing all commas \",\" , make it not a valid json format and cannot use jq to further action",
      "My expected output is valid json like",
      "NETWORK_INTERFACE=$(aws ec2 describe-network-interfaces --filters Name=vpc-id,Values=\"${VPC_ID}\" --output json | jq -r '[.NetworkInterfaces[] | {AvailabilityZone, Description, Groups}]')",
      "Based on your sample output I have filtered out the fields `AvailabilityZone`, `Description` and `Groups`."
    ],
    "utterance": "Select an array of objects with the fields AvailabilityZone, Description, and Groups from each network interface under NetworkInterfaces, preserving valid formatting.",
    "expressions": [
      "[.NetworkInterfaces[] | {AvailabilityZone, Description, Groups}]"
    ],
    "identifier": 78422524,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "jq --arg url \"$URL\" '.defaultOptions.environmentVariableEntries += [{\"key\": \"URL\", \"value\": $url}]' json.xctestplan",
      "The output is:",
      "{\n  \"defaultOptions\": {\n    \"environmentVariableEntries\": [\n      {\n        \"key\": \"OS_VERSION\",\n        \"value\": \"13\"\n      },\n      {\n        \"key\": \"URL\",\n        \"value\": \"https://www.google.com\"\n      }\n    ]\n  }\n}",
      "sh \"jq --arg url \\\"$URL\\\" '.defaultOptions.environmentVariableEntries += [{\\\"key\\\": \\\"URL\\\", \\\"value\\\": \\$url}]' json.xctestplan > json.xctestplan.tmp\"",
      "sh \"mv json.xctestplan.tmp json.xctestplan\""
    ],
    "utterance": "Add an entry with key 'URL' and a given value to the environmentVariableEntries array under defaultOptions, preserving existing entries.",
    "expressions": [
      ".defaultOptions.environmentVariableEntries += [{\"key\": \"URL\", \"value\": $url}]"
    ],
    "data": [
      {
        "input": {
          "defaultOptions": {
            "environmentVariableEntries": [
              {
                "key": "OS_VERSION",
                "value": "13"
              }
            ]
          }
        },
        "output": {
          "defaultOptions": {
            "environmentVariableEntries": [
              {
                "key": "OS_VERSION",
                "value": "13"
              },
              {
                "key": "URL",
                "value": "https://www.google.com"
              }
            ]
          }
        }
      }
    ],
    "identifier": 78429844,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I need to override the property `version` with the value of `image`. The problem is, that the json document can have several forms, whereby parts of the nesting can be flattened",
      "Is it possible to define a single jq query, which can handle several forms of nesting (from a flat form to a nested form) and so, that the form of the input is also preserved in the output?",
      "You can use `walk` to traverse the document, and update `|=` matching nodes (e.g. objects that have a `version` key) using a given filter (e.g. assigning the value of `.settings.image` to `.version`):",
      "walk(select(type == \"object\" and has(\"version\")) |= (.version = .settings.image))"
    ],
    "utterance": "Override each version property with the value of the image property from the sibling settings object, regardless of flattening or nesting, while preserving the input structure.",
    "expressions": [
      "walk(select(type == \"object\" and has(\"version\")) |= (.version = .settings.image))"
    ],
    "data": [
      {
        "input": {
          "modulesContent": {
            "$edgeAgent": {
              "properties.desired.modules.event-bridge-redis": {
                "settings": {
                  "image": "redis:6.2.7",
                  "createOptions": ""
                },
                "type": "docker",
                "status": "running",
                "restartPolicy": "always",
                "version": "1.0"
              },
              "properties.desired.modules.event-bridge-metrics": {
                "settings": {
                  "image": "mcr.microsoft.com/azureiotedge-metrics-collector:1.19",
                  "createOptions": ""
                },
                "type": "docker",
                "version": "1.0",
                "status": "running",
                "restartPolicy": "always"
              }
            },
            "$edgeHub": {}
          }
        },
        "output": {
          "modulesContent": {
            "$edgeAgent": {
              "properties.desired.modules.event-bridge-redis": {
                "settings": {
                  "image": "redis:6.2.7",
                  "createOptions": ""
                },
                "type": "docker",
                "status": "running",
                "restartPolicy": "always",
                "version": "redis:6.2.7"
              },
              "properties.desired.modules.event-bridge-metrics": {
                "settings": {
                  "image": "mcr.microsoft.com/azureiotedge-metrics-collector:1.19",
                  "createOptions": ""
                },
                "type": "docker",
                "version": "mcr.microsoft.com/azureiotedge-metrics-collector:1.19",
                "status": "running",
                "restartPolicy": "always"
              }
            },
            "$edgeHub": {}
          }
        }
      },
      {
        "input": {
          "modulesContent": {
            "$edgeAgent": {
              "properties.desired.modules": {
                "event-bridge-redis": {
                  "settings": {
                    "image": "redis:6.2.7",
                    "createOptions": ""
                  },
                  "type": "docker",
                  "status": "running",
                  "restartPolicy": "always",
                  "version": "1.0"
                },
                "event-bridge-metrics": {
                  "settings": {
                    "image": "mcr.microsoft.com/azureiotedge-metrics-collector:1.19",
                    "createOptions": ""
                  },
                  "type": "docker",
                  "version": "1.0",
                  "status": "running",
                  "restartPolicy": "always"
                }
              }
            },
            "$edgeHub": {}
          }
        },
        "output": {
          "modulesContent": {
            "$edgeAgent": {
              "properties.desired.modules": {
                "event-bridge-redis": {
                  "settings": {
                    "image": "redis:6.2.7",
                    "createOptions": ""
                  },
                  "type": "docker",
                  "status": "running",
                  "restartPolicy": "always",
                  "version": "redis:6.2.7"
                },
                "event-bridge-metrics": {
                  "settings": {
                    "image": "mcr.microsoft.com/azureiotedge-metrics-collector:1.19",
                    "createOptions": ""
                  },
                  "type": "docker",
                  "version": "mcr.microsoft.com/azureiotedge-metrics-collector:1.19",
                  "status": "running",
                  "restartPolicy": "always"
                }
              }
            },
            "$edgeHub": {}
          }
        }
      }
    ],
    "identifier": 78441252,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "How to revise the code so that if \"message\" is a field of the value of `.value`, then print \"X\", otherwise print \"Y\"?",
      "Instead, you can check to ensure that `.` is an `object`, as well as checking for the existence of the key, with `if type == \"object\" and .message?`.",
      "$  jq '.value|if type == \"object\" and .message? then \"X\" else \"Y\" end' <<< '{\"value\":true}'",
      "\"Y\"",
      "$  jq '.value|if type == \"object\" and .message? then \"X\" else \"Y\" end' <<< '{\"value\":{\"message\": true}}'",
      "\"X\"",
      "$  jq '.value|if type == \"object\" and .message? then \"X\" else \"Y\" end' <<< '{\"value\":{\"notmessage\": true}}'",
      "\"Y\""
    ],
    "utterance": "Print X if .value has a field named message; otherwise, print Y.",
    "expressions": [
      ".value | if type == \"object\" and .message? then \"X\" else \"Y\" end"
    ],
    "data": [
      {
        "input": {
          "value": true
        },
        "output": "Y"
      },
      {
        "input": {
          "value": {
            "message": true
          }
        },
        "output": "X"
      },
      {
        "input": {
          "value": {
            "notmessage": true
          }
        },
        "output": "Y"
      }
    ],
    "identifier": 78446017,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to control what is printed when the input json is not valid. For example, I may want to prepend something to the original error message.",
      "jq -R 'try fromjson catch error(\"my custom error\")'",
      "Assuming you are running from a bash shell, you could capture the error output and process it any way you want. In the example below I am putting \"xxx:\" in front of every line and sending the output to standard error:",
      "sed -e 's/\\(.*\\)/xxx:\\1/' < tmpfile.$$ 1>&2 "
    ],
    "utterance": "Prepend a custom prefix to the error message shown when the input is not valid.",
    "expressions": [
      "jq -R 'try fromjson catch error(\"my custom error\")'"
    ],
    "identifier": 78447656,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": true
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "cat ${{env.DOTNET_ROOT}}/myapp/appsettings.json | jq --arg my_secret ${{secrets.SQL_CONNECTION_STRING}} --arg email_secret ${{secrets.EMAIL_PASSWORD}} '.Config.SiteDb = $my_secret | .Config.EmailPassword = $email_secret' > newfile.json",
      "cat ${{env.DOTNET_ROOT}}/myapp/appsettings.json | jq --arg my_secret \"$SQL_CONNECTION_STRING\" --arg email_secret \"$EMAIL_PASSWORD\" '.Config.SiteDb = $my_secret | .Config.EmailPassword = $email_secret' > newfile.json"
    ],
    "utterance": "Update the values of Config.SiteDb and Config.EmailPassword with the contents of variables my_secret and email_secret, respectively.",
    "expressions": [
      ".Config.SiteDb = $my_secret | .Config.EmailPassword = $email_secret"
    ],
    "identifier": 78450153,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I would like an output like this:\n08/05/2024,string11,string12,string13\n08/05/2024,string21,string22,string23\n09/05/2024,string11,string12,string13\n09/05/2024,string21,string22,string23",
      "jq -r '.[] | . as {$date} | .results[] | [$date, .[]] | @csv'",
      "jq -r '.[] | [.date] + (.results[] | [.[]]) | @csv'",
      "Replace the latter `.[]` with `.field1, .field2, .field3` to be explicit."
    ],
    "utterance": "For each result, output a CSV row containing its parent object's date followed by the values of field1, field2, and field3.",
    "expressions": [
      ".[] | . as {$date} | .results[] | [$date, .field1, .field2, .field3] | @csv",
      ".[] | [.date] + (.results[] | [.field1, .field2, .field3]) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "date": "date1",
            "results": [
              {
                "field1": "string11",
                "field2": "string12",
                "field3": "string13"
              },
              {
                "field1": "string21",
                "field2": "string22",
                "field3": "string23"
              }
            ]
          },
          {
            "date": "date2",
            "results": [
              {
                "field1": "string11",
                "field2": "string12",
                "field3": "string13"
              },
              {
                "field1": "string21",
                "field2": "string22",
                "field3": "string23"
              }
            ]
          }
        ],
        "output": [
          "\"date1\",\"string11\",\"string12\",\"string13\"",
          "\"date1\",\"string21\",\"string22\",\"string23\"",
          "\"date2\",\"string11\",\"string12\",\"string13\"",
          "\"date2\",\"string21\",\"string22\",\"string23\""
        ]
      }
    ],
    "identifier": 78456512,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I am trying to write a BASH+jq one liner to only return the entries that are less than 5 minutes old as I am writing automation to only look back 5 minutes (BASH).",
      "the date being returned for `created_at` is in EST",
      "This query fails:\n\n`jq  '.[] | .created_at |= .[0:19] | select(.created_at | fromdate - 300)'`",
      "Either use the [Go implementation of jq](https://github.com/itchyny/gojq), which can parse `%z` correctly:",
      "gojq '\n  map(select(\n    .created_at | sub(\"\\\\.[0-9]+\"; \"\")\n    | strptime(\"%FT%T%z\") | now - mktime <= 300\n  ))\n'",
      "Or manually interpret the (numeric) timezone (as `(+|-)HH[:]MM`), and do the math:\n```sh\nmap(select(\n  .created_at | sub(\"\\\\.[0-9]+\"; \"\")\n  | ( capture(\".{19}(?<d>[+-])(?<h>[0-9]{2}):?(?<m>[0-9]{2})\")\n      | .d += \"1\" | .[] |= tonumber\n    ) as $tz\n  | strptime(\"%FT%T%z\") | .[3] -= $tz.d * $tz.h | .[4] -= $tz.d * $tz.m\n  | now - mktime <= 300\n))"
    ],
    "utterance": "Return all entries whose created_at field is less than or equal to 5 minutes ago, correctly handling timezones in the created_at ISO 8601 string with non-UTC offset.",
    "expressions": [
      "map(select(\n  .created_at | sub(\"\\\\.[0-9]+\"; \"\")\n  | strptime(\"%FT%T%z\") | now - mktime <= 300\n))",
      "map(select(\n  .created_at | sub(\"\\\\.[0-9]+\"; \"\")\n  | ( capture(\".{19}(?<d>[+-])(?<h>[0-9]{2}):?(?<m>[0-9]{2})\")\n      | .d += \"1\" | .[] |= tonumber\n    ) as $tz\n  | strptime(\"%FT%T%z\") | .[3] -= $tz.d * $tz.h | .[4] -= $tz.d * $tz.m\n  | now - mktime <= 300\n))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 621024,
            "iid": 99999,
            "project_id": 999,
            "sha": "faf897sd98fa987afsd98f7",
            "ref": "master",
            "status": "running",
            "source": "push",
            "created_at": "2024-05-10T16:32:01.072-04:00",
            "updated_at": "2024-05-10T16:32:03.565-04:00",
            "web_url": "https://gitlab/pipelines/9999",
            "name": null
          },
          {
            "id": 621023,
            "iid": 99999,
            "project_id": 999,
            "sha": "faf897sd98fa987afsd98f7",
            "ref": "master",
            "status": "success",
            "source": "push",
            "created_at": "2024-05-10T16:31:47.951-04:00",
            "updated_at": "2024-05-10T16:35:30.362-04:00",
            "web_url": "https://gitlab/pipelines/9999",
            "name": null
          },
          {
            "id": 621020,
            "iid": 99999,
            "project_id": 999,
            "sha": "faf897sd98fa987afsd98f7",
            "ref": "master",
            "status": "waiting_for_resource",
            "source": "push",
            "created_at": "2024-05-10T15:27:00.248-04:00",
            "updated_at": "2024-05-10T15:30:14.172-04:00",
            "web_url": "https://gitlab/pipelines/9999",
            "name": null
          },
          {
            "id": 621019,
            "iid": 99999,
            "project_id": 999,
            "sha": "faf897sd98fa987afsd98f7",
            "ref": "master",
            "status": "success",
            "source": "push",
            "created_at": "2024-05-10T14:26:02.235-04:00",
            "updated_at": "2024-05-10T14:29:45.406-04:00",
            "web_url": "https://gitlab/pipelines/9999",
            "name": null
          }
        ]
      }
    ],
    "identifier": 78462479,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "jq 'pick(.id,.title,.webpage_url,.channel,.duration_string,.upload_date)' *.info.json",
      "jq --arg Date=\"$Date\" 'pick(.id,.title,.webpage_url,.channel,.duration_string,.upload_date) + {\"date\": $Date}' *.info.json",
      "Pick and Append produces same output as Pick and is not appending date. Why and how can I correct this?",
      "## Expected Output\n\n{\n  \"id\": \"uO8Sn0Xch1s\",\n  \"title\": \"A transformative new way of classifying foods \ud83c\udf54\ud83c\udf55\ud83c\udf5f BBC\",\n  \"webpage_url\": \"https://www.youtube.com/watch?v=uO8Sn0Xch1s\",\n  \"channel\": \"BBC\",\n  \"duration_string\": \"4:19\",\n  \"upload_date\": \"20210701\",\n  \"date\": \"2024-05-10\"\n}"
    ],
    "utterance": "Select the fields id, title, webpage_url, channel, duration_string, and upload_date and add a field date with a given value.",
    "expressions": [
      "jq --arg Date \"$Date\" 'pick(.id,.title,.webpage_url,.channel,.duration_string,.upload_date) + {\"date\": $Date}' *.info.json"
    ],
    "data": [
      {
        "input": {
          "id": "uO8Sn0Xch1s",
          "title": "A transformative new way of classifying foods \ud83c\udf54\ud83c\udf55\ud83c\udf5f BBC",
          "webpage_url": "https://www.youtube.com/watch?v=uO8Sn0Xch1s",
          "channel": "BBC",
          "duration_string": "4:19",
          "upload_date": "20210701"
        },
        "output": {
          "id": "uO8Sn0Xch1s",
          "title": "A transformative new way of classifying foods \ud83c\udf54\ud83c\udf55\ud83c\udf5f BBC",
          "webpage_url": "https://www.youtube.com/watch?v=uO8Sn0Xch1s",
          "channel": "BBC",
          "duration_string": "4:19",
          "upload_date": "20210701",
          "date": "2024-05-10"
        }
      }
    ],
    "identifier": 78462605,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have a script, that returns quoted JSON data, like `&quot;{\\&quot;F1\\&quot;:null,\\&quot;F2\\&quot;:\\&quot;text\\&quot;...`",
      "How can I evaluate it and return &quot;clear&quot; data to feed it into `jq`?",
      "You can either use [`fromjson`](https://jqlang.github.io/jq/manual/#convert-to-from-json) as the initial filter in your jq program or use jq once to print the raw string contents:",
      "echo '\"{\\\"F1\\\":null,\\\"F2\\\":\\\"text\\\"}\"' | jq 'fromjson | ...'",
      "or",
      "echo '\"{\\\"F1\\\":null,\\\"F2\\\":\\\"text\\\"}\"' | jq -r . | jq '...'"
    ],
    "utterance": "Convert a double-quoted, JSON-encoded string to usable data for further querying, so the contained fields can be accessed directly.",
    "expressions": [
      "fromjson"
    ],
    "data": [
      {
        "input": "\"{\\\"F1\\\":null,\\\"F2\\\":\\\"text\\\"}\"",
        "output": {
          "F1": null,
          "F2": "text"
        }
      }
    ],
    "identifier": 78465261,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "\".time| strptime(\"%Y-%m-%d %H:%M:%S.%f\")| strftime(\"%Y\")\"",
      "\"It clearly is not agreeing that I have this format, however this is exactly the format I'm using in Python.\"",
      "\"jq does not support %f so there are a number of solutions to work around this.\"",
      "\"As soon as I remove the .%f jq is able to parse the dates.\"",
      "\"If all you need is %Y from a date string that is already formatted starting with %Y-, just extract its first four characters:\"",
      "\"jq '.time[:4]'\""
    ],
    "utterance": "Extract the year from a time string formatted as 'YYYY-MM-DD HH:MM:SS.ssssss'.",
    "expressions": [
      ".time[:4]"
    ],
    "data": [
      {
        "input": {
          "time": "2024-05-13 16:43:06.928708"
        },
        "output": "2024"
      }
    ],
    "identifier": 78474940,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I'd like to change from:\n{\n  \"resources\": [\n    {\n      \"provider\": \"something_else\",\n      \"type\": \"foo\"\n    },\n    {\n      \"provider\": \"provider[\\\"registry.terraform.io/eddycharly/kops\\\"]\",\n      \"type\": \"kops_cluster\",\n      \"instances\": [{\n        \"attributes\": {\n          \"another_attr\": \"hello world\",\n          \"config_base\": \"s3://foo-bucket/bar-env\",\n          \"config_store\": \"\"\n        }\n      }]\n    },\n    {\n      \"provider\": \"something_else\",\n      \"type\": \"foo\"\n    }\n  ]\n}\n\nTo:\n{\n  \"resources\": [\n    {\n      \"provider\": \"something_else\",\n      \"type\": \"foo\"\n    },\n    {\n      \"provider\": \"provider[\\\"registry.terraform.io/eddycharly/kops\\\"]\",\n      \"type\": \"kops_cluster\",\n      \"instances\": [{\n        \"attributes\": {\n          \"another_attr\": \"hello world\",\n          \"config_store\": [{\n            \"base\": \"s3://foo-bucket/bar-env\"\n          }]\n        }\n      }]\n    },\n    {\n      \"provider\": \"something_else\",\n      \"type\": \"foo\"\n    }\n  ]\n}\n",
      "but the resulting output is only the modified `.resources[].instances[].attributes` block, not the entire document",
      "How can I rearrange this expression to output the entire document?",
      "You're looking for something like this:\n(\n  .resources[] | \n  select(\n    .provider == \"provider[\\\"registry.terraform.io/eddycharly/kops\\\"]\" and\n    .type == \"kops_cluster\"\n  ) |\n  .instances[].attributes\n) |= (\n  .config_store = [{ base:.config_base }] |\n  del(.config_base)\n)\nYou need to parenthesize the lefthand side of `|=` to retain the original structure."
    ],
    "utterance": "For each resource where provider is \"provider[\\\"registry.terraform.io/eddycharly/kops\\\"]\" and type is \"kops_cluster\", move the value of attributes.config_base to attributes.config_store as [{\"base\": ...}], and remove config_base, outputting the full modified document.",
    "expressions": [
      "(\n  .resources[] | \n  select(\n    .provider == \"provider[\\\"registry.terraform.io/eddycharly/kops\\\"]\" and\n    .type == \"kops_cluster\"\n  ) |\n  .instances[].attributes\n) |= (\n  .config_store = [{ base:.config_base }] |\n  del(.config_base)\n)"
    ],
    "data": [
      {
        "input": {
          "resources": [
            {
              "provider": "something_else",
              "type": "foo"
            },
            {
              "provider": "provider[\"registry.terraform.io/eddycharly/kops\"]",
              "type": "kops_cluster",
              "instances": [
                {
                  "attributes": {
                    "another_attr": "hello world",
                    "config_base": "s3://foo-bucket/bar-env",
                    "config_store": ""
                  }
                }
              ]
            },
            {
              "provider": "something_else",
              "type": "foo"
            }
          ]
        },
        "output": {
          "resources": [
            {
              "provider": "something_else",
              "type": "foo"
            },
            {
              "provider": "provider[\"registry.terraform.io/eddycharly/kops\"]",
              "type": "kops_cluster",
              "instances": [
                {
                  "attributes": {
                    "another_attr": "hello world",
                    "config_store": [
                      {
                        "base": "s3://foo-bucket/bar-env"
                      }
                    ]
                  }
                }
              ]
            },
            {
              "provider": "something_else",
              "type": "foo"
            }
          ]
        }
      }
    ],
    "identifier": 78475026,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  }
]