Hi, I'd like to get some feedback on the json output, the overall structure of the information and naming.
Code: git://github.com/kdave/btrfs-progs.git preview-json The one example command that supports it is $ ./btrfs --format json subvolume show /mnt The test tests/cli-tests/011-* can demonstrate the capabilities. The json formatter and example use are in the top commits, otherwise the branch contains lot of unrelated changes. Example output: { "__header": { "version": "1" }, "subvolume-show": { "path": "subv2", "name": "subv2", "uuid": "9178604e-e961-ef40-a5f0-2c109126b209", "parent_uuid": "9178604e-e961-ef40-a5f0-2c109126b209", "received_uuid": "9178604e-e961-ef40-a5f0-2c109126b209", "otime": "2019-06-25 17:15:28 +0200", "subvolume_id": "256", "generation": "6", "parent_id": "5", "toplevel_id": "5", "flags": "-", "snapshots": [ ], "quota-group": { "qgroupid": "0/256", "qgroup-limit-referenced": "-", "qgroup-limit-exclusive": "-", "qgroup-usage-referenced": "16.00KiB", "qgroup-usage-exclusive": "16.00KiB" } } } The current proposal: - the toplevel group contains 2 maps, one is some generic header, to identify version of the format or the version of progs that produces it or whatever could be useful and I did not think of it - the 2nd map is named according to the command that generated the output, this is to be able to merge outputs from several commands, or to somehow define the contents of the map Compare that to a simple unnamed group with bunch of values: { "path": "subv2", "name": "subv2", "uuid": "9178604e-e961-ef40-a5f0-2c109126b209", "parent_uuid": "9178604e-e961-ef40-a5f0-2c109126b209", "received_uuid": "9178604e-e961-ef40-a5f0-2c109126b209", "otime": "2019-06-25 17:15:28 +0200", "subvolume_id": "256", "generation": "6", "parent_id": "5", "toplevel_id": "5", "flags": "-", "snapshots": [ ], "quota-group": { "qgroupid": "0/256", "qgroup-limit-referenced": "-", "qgroup-limit-exclusive": "-", "qgroup-usage-referenced": "16.00KiB", "qgroup-usage-exclusive": "16.00KiB" } } That's a bit shorter but makes validation harder. I assume that the output would be accessed programatically like (python pseudo-code) --- rawjson = output_of_command("btrfs --format json subvolume show /mnt") json = Json.from_string(rawjson) if json["subvolume-show"]["flags"] != "-": print("Subvolume %s has flags", json["subvolume-show"]["name"]) --- so the latter is subset of the former, without one map reference. Once the json format is settled, more commands can be easily converted.