)]}'
{"id":"openstack%2Fliberasurecode~969545","triplet_id":"openstack%2Fliberasurecode~master~Ifa373e4ef8ef3caedb709c40c2b2bfd6fdf6ff7e","project":"openstack/liberasurecode","branch":"master","attention_set":{},"removed_from_attention_set":{"7233":{"account":{"_account_id":7233,"name":"Matthew Oliver","email":"matt@oliver.net.au","username":"mattoliverau"},"last_update":"2026-01-15 00:22:28.000000000","reason":"\u003cGERRIT_ACCOUNT_7233\u003e replied on the change","reason_account":{"_account_id":7233,"name":"Matthew Oliver","email":"matt@oliver.net.au","username":"mattoliverau"}},"15343":{"account":{"_account_id":15343,"name":"Tim Burke","email":"tburke@nvidia.com","username":"tburke"},"last_update":"2026-01-15 00:50:00.000000000","reason":"Change was submitted"}},"hashtags":[],"change_id":"Ifa373e4ef8ef3caedb709c40c2b2bfd6fdf6ff7e","subject":"Add optional check_reconstruct_fragments function","status":"MERGED","created":"2025-12-04 00:09:33.000000000","updated":"2026-01-15 00:50:00.000000000","submitted":"2026-01-15 00:50:00.000000000","submitter":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"total_comment_count":7,"unresolved_comment_count":0,"has_review_started":true,"submission_id":"969545","meta_rev_id":"3153a29ed68411c1742c8f418a10e53ded27c9b6","_number":969545,"virtual_id_number":969545,"owner":{"_account_id":15343,"name":"Tim Burke","email":"tburke@nvidia.com","username":"tburke"},"actions":{},"labels":{"Verified":{"approved":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"all":[{"value":0,"_account_id":7233,"name":"Matthew Oliver","email":"matt@oliver.net.au","username":"mattoliverau"},{"tag":"autogenerated:zuul:gate","value":2,"date":"2026-01-15 00:50:00.000000000","permitted_voting_range":{"min":2,"max":2},"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]}],"values":{"-2":"Fails","-1":"Doesn\u0027t seem to work"," 0":"No score","+1":"Works for me","+2":"Verified"},"description":"","default_value":0,"optional":true},"Code-Review":{"approved":{"_account_id":7233,"name":"Matthew Oliver","email":"matt@oliver.net.au","username":"mattoliverau"},"all":[{"value":2,"date":"2026-01-15 00:22:28.000000000","permitted_voting_range":{"min":2,"max":2},"_account_id":7233,"name":"Matthew Oliver","email":"matt@oliver.net.au","username":"mattoliverau"},{"value":0,"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]}],"values":{"-2":"Do not merge","-1":"This patch needs further work before it can be merged"," 0":"No score","+1":"Looks good to me, but someone else must approve","+2":"Looks good to me (core reviewer)"},"description":"","default_value":0,"optional":true},"Workflow":{"approved":{"_account_id":7233,"name":"Matthew Oliver","email":"matt@oliver.net.au","username":"mattoliverau"},"all":[{"value":1,"date":"2026-01-15 00:22:28.000000000","permitted_voting_range":{"min":1,"max":1},"_account_id":7233,"name":"Matthew Oliver","email":"matt@oliver.net.au","username":"mattoliverau"},{"value":0,"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]}],"values":{"-1":"Work in progress"," 0":"Ready for reviews","+1":"Approved"},"description":"","default_value":0,"optional":true}},"removable_reviewers":[],"reviewers":{"REVIEWER":[{"_account_id":7233,"name":"Matthew Oliver","email":"matt@oliver.net.au","username":"mattoliverau"},{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]}]},"pending_reviewers":{},"reviewer_updates":[{"updated":"2025-12-04 00:21:18.000000000","updated_by":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"reviewer":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"state":"REVIEWER"},{"updated":"2026-01-11 22:55:09.000000000","updated_by":{"_account_id":7233,"name":"Matthew Oliver","email":"matt@oliver.net.au","username":"mattoliverau"},"reviewer":{"_account_id":7233,"name":"Matthew Oliver","email":"matt@oliver.net.au","username":"mattoliverau"},"state":"REVIEWER"}],"messages":[{"id":"fd12a75df7aebb3a9a88b3fabbdab216ec0784be","tag":"autogenerated:gerrit:newPatchSet","author":{"_account_id":15343,"name":"Tim Burke","email":"tburke@nvidia.com","username":"tburke"},"date":"2025-12-04 00:09:33.000000000","message":"Uploaded patch set 1.","accounts_in_message":[],"_revision_number":1},{"id":"fb9da17d62d70de49d6441b6c0f02048bc46207e","tag":"autogenerated:zuul:check","author":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"date":"2025-12-04 00:21:18.000000000","message":"Patch Set 1: Verified+1\n\nBuild succeeded (check pipeline).\nhttps://zuul.opendev.org/t/openstack/buildset/9030b24b8df448ba88f974ecff6a4ac6\n\n- liberasurecode-unittests https://zuul.opendev.org/t/openstack/build/d6a21d26cdd141fd81416a8ccaf2b918 : SUCCESS in 9m 07s\n- liberasurecode-unittests-centos-9-stream https://zuul.opendev.org/t/openstack/build/d1fe86163186414e81b9e6968cc74daf : SUCCESS in 8m 54s\n- liberasurecode-unittests-centos-9-stream-fips https://zuul.opendev.org/t/openstack/build/2a4e474b66614cbbbb4c7872131de3fd : SUCCESS in 11m 02s","accounts_in_message":[],"_revision_number":1},{"id":"a6532b37365e7222e9cd0b53db4575e11e727868","tag":"autogenerated:zuul:check-arm64","author":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"date":"2025-12-04 00:32:04.000000000","message":"Patch Set 1:\n\nBuild succeeded (ARM64 pipeline).\nhttps://zuul.opendev.org/t/openstack/buildset/d02ce9685ab147a292ac94441b4ed150\n\n- liberasurecode-unittests-arm64 https://zuul.opendev.org/t/openstack/build/3290f225e4b14018b32241dcae16267c : SUCCESS in 20m 12s","accounts_in_message":[],"_revision_number":1},{"id":"50dd432cf11a0619d1e65b919e8fbb8fac1523fa","author":{"_account_id":15343,"name":"Tim Burke","email":"tburke@nvidia.com","username":"tburke"},"date":"2025-12-07 21:36:53.000000000","message":"Patch Set 1:\n\n(2 comments)","accounts_in_message":[],"_revision_number":1},{"id":"f14cfbef845958341c520fe6e8fd27a92857c146","author":{"_account_id":7233,"name":"Matthew Oliver","email":"matt@oliver.net.au","username":"mattoliverau"},"date":"2026-01-11 22:55:09.000000000","message":"Patch Set 1: Code-Review-1\n\n(1 comment)","accounts_in_message":[],"_revision_number":1},{"id":"0c676ea5b0c74d6632e00ee5ab3242511e90444d","author":{"_account_id":15343,"name":"Tim Burke","email":"tburke@nvidia.com","username":"tburke"},"date":"2026-01-12 17:56:19.000000000","message":"Patch Set 1:\n\n(2 comments)","accounts_in_message":[],"_revision_number":1},{"id":"dd23f6d244ace0a0d83732437d748c14bf81610b","tag":"autogenerated:gerrit:newPatchSet","author":{"_account_id":15343,"name":"Tim Burke","email":"tburke@nvidia.com","username":"tburke"},"date":"2026-01-12 17:56:33.000000000","message":"Uploaded patch set 2.\n\nOutdated Votes:\n* Code-Review-1 (copy condition: \"changekind:TRIVIAL_REBASE OR is:MIN\")\n* Verified+1\n","accounts_in_message":[],"_revision_number":2},{"id":"414c5612bafd18ffc6670685f619f38988881529","tag":"autogenerated:zuul:check-arm64","author":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"date":"2026-01-12 18:28:10.000000000","message":"Patch Set 2:\n\nBuild succeeded (ARM64 pipeline).\nhttps://zuul.opendev.org/t/openstack/buildset/2d8a9ed8e8c642a59ae0b9dc2468d131\n\n- liberasurecode-unittests-arm64 https://zuul.opendev.org/t/openstack/build/15d54af15e38494ba41ba2b9af2c857a : SUCCESS in 13m 51s","accounts_in_message":[],"_revision_number":2},{"id":"4dbf131fd3f4107cfa6d0b513f7c3d0068eaab33","tag":"autogenerated:zuul:check","author":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"date":"2026-01-12 18:36:24.000000000","message":"Patch Set 2: Verified+1\n\nBuild succeeded (check pipeline).\nhttps://zuul.opendev.org/t/openstack/buildset/e1efac2ee36c44fb944d0c3aa16e4cb6\n\n- liberasurecode-unittests https://zuul.opendev.org/t/openstack/build/b60dc81b217e4150be6f5a6457ddeaed : SUCCESS in 9m 31s\n- liberasurecode-unittests-centos-9-stream https://zuul.opendev.org/t/openstack/build/589141c66ee84fb5956a606466c599cc : SUCCESS in 20m 16s\n- liberasurecode-unittests-centos-9-stream-fips https://zuul.opendev.org/t/openstack/build/4351601b638040e1a068bd36bb7c9b7d : SUCCESS in 20m 58s","accounts_in_message":[],"_revision_number":2},{"id":"058ae7dd37de28f876f9d9fe7188617807a1ca97","author":{"_account_id":7233,"name":"Matthew Oliver","email":"matt@oliver.net.au","username":"mattoliverau"},"date":"2026-01-15 00:22:28.000000000","message":"Patch Set 2: Code-Review+2 Workflow+1\n\n(2 comments)","accounts_in_message":[],"_revision_number":2},{"id":"aca49a03422d9a10a5265e254e1b374c64e2a69b","tag":"autogenerated:zuul:gate","author":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"date":"2026-01-15 00:22:46.000000000","message":"Patch Set 2: -Verified\n\nStarting gate jobs.","accounts_in_message":[],"_revision_number":2},{"id":"110489f7a68972e796525d02c44753475042d0e3","tag":"autogenerated:zuul:gate","author":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"date":"2026-01-15 00:50:00.000000000","message":"Patch Set 2: Verified+2\n\nBuild succeeded (gate pipeline).\nhttps://zuul.opendev.org/t/openstack/buildset/b49ddf2f99eb45c39d311cbb6b54cb2b\n\n- liberasurecode-unittests https://zuul.opendev.org/t/openstack/build/932ffdb457b14a7b84f2b5b3d9830537 : SUCCESS in 8m 41s\n- liberasurecode-unittests-centos-9-stream https://zuul.opendev.org/t/openstack/build/e257f6953d07431a87178e8d34b271c7 : SUCCESS in 18m 47s\n- liberasurecode-unittests-centos-9-stream-fips https://zuul.opendev.org/t/openstack/build/e7d6b93d4fd64fd580b2ec44f6a7f223 : SUCCESS in 22m 16s","accounts_in_message":[],"_revision_number":2},{"id":"3153a29ed68411c1742c8f418a10e53ded27c9b6","tag":"autogenerated:gerrit:merged","author":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"date":"2026-01-15 00:50:00.000000000","message":"Change has been successfully merged","accounts_in_message":[],"_revision_number":2}],"current_revision_number":2,"current_revision":"a87ddc707189795666631005898daf1f43df3967","revisions":{"92289d6799bc6423bec3eb63ae8a580ba14c98fc":{"kind":"REWORK","_number":1,"created":"2025-12-04 00:09:33.000000000","uploader":{"_account_id":15343,"name":"Tim Burke","email":"tburke@nvidia.com","username":"tburke"},"ref":"refs/changes/45/969545/1","fetch":{"anonymous http":{"url":"https://review.opendev.org/openstack/liberasurecode","ref":"refs/changes/45/969545/1","commands":{"Checkout":"git fetch https://review.opendev.org/openstack/liberasurecode refs/changes/45/969545/1 \u0026\u0026 git checkout FETCH_HEAD","Cherry Pick":"git fetch https://review.opendev.org/openstack/liberasurecode refs/changes/45/969545/1 \u0026\u0026 git cherry-pick FETCH_HEAD","Format Patch":"git fetch https://review.opendev.org/openstack/liberasurecode refs/changes/45/969545/1 \u0026\u0026 git format-patch -1 --stdout FETCH_HEAD","Pull":"git pull https://review.opendev.org/openstack/liberasurecode refs/changes/45/969545/1"}}},"commit":{"parents":[{"commit":"f29fb7e0e47826cb9655f719550779ceed9dc583","subject":"Move EINSUFFFRAGS checking from get_fragment_partition to caller","web_links":[{"name":"gitea","tooltip":"Open in GitWeb","url":"https://opendev.org/openstack/liberasurecode/commit/f29fb7e0e47826cb9655f719550779ceed9dc583"}]}],"author":{"name":"Tim Burke","email":"tim.burke@gmail.com","date":"2025-12-03 23:58:54.000000000","tz":-480},"committer":{"name":"Tim Burke","email":"tim.burke@gmail.com","date":"2025-12-04 00:08:54.000000000","tz":-480},"subject":"Add optional check_reconstruct_fragments function","message":"Add optional check_reconstruct_fragments function\n\nThis function should return either 0 or -EINSUFFFRAGS and can be used\nas a quick check ahead of actually attempting reconstruction. If not\nprovided, default to checking for at least k fragments.\n\nImplement the new function for flat xor codes so they can reconstruct\nin more cases.\n\nDepends-On: https://review.opendev.org/c/openstack/liberasurecode/+/969331\nChange-Id: Ifa373e4ef8ef3caedb709c40c2b2bfd6fdf6ff7e\nSigned-off-by: Tim Burke \u003ctim.burke@gmail.com\u003e\n","web_links":[{"name":"gitea","tooltip":"Open in GitWeb","url":"https://opendev.org/openstack/liberasurecode/commit/92289d6799bc6423bec3eb63ae8a580ba14c98fc"}],"resolve_conflicts_web_links":[{"name":"gitea","tooltip":"Open in GitWeb","url":"https://opendev.org/openstack/liberasurecode/commit/92289d6799bc6423bec3eb63ae8a580ba14c98fc"}]},"branch":"refs/heads/master"},"a87ddc707189795666631005898daf1f43df3967":{"kind":"REWORK","_number":2,"created":"2026-01-12 17:56:33.000000000","uploader":{"_account_id":15343,"name":"Tim Burke","email":"tburke@nvidia.com","username":"tburke"},"ref":"refs/changes/45/969545/2","fetch":{"anonymous http":{"url":"https://review.opendev.org/openstack/liberasurecode","ref":"refs/changes/45/969545/2","commands":{"Checkout":"git fetch https://review.opendev.org/openstack/liberasurecode refs/changes/45/969545/2 \u0026\u0026 git checkout FETCH_HEAD","Cherry Pick":"git fetch https://review.opendev.org/openstack/liberasurecode refs/changes/45/969545/2 \u0026\u0026 git cherry-pick FETCH_HEAD","Format Patch":"git fetch https://review.opendev.org/openstack/liberasurecode refs/changes/45/969545/2 \u0026\u0026 git format-patch -1 --stdout FETCH_HEAD","Pull":"git pull https://review.opendev.org/openstack/liberasurecode refs/changes/45/969545/2"}}},"commit":{"parents":[{"commit":"f903a160099778ce37da238e43d1acbec1281af4","subject":"Move EINSUFFFRAGS checking from get_fragment_partition to caller","web_links":[{"name":"gitea","tooltip":"Open in GitWeb","url":"https://opendev.org/openstack/liberasurecode/commit/f903a160099778ce37da238e43d1acbec1281af4"}]}],"author":{"name":"Tim Burke","email":"tim.burke@gmail.com","date":"2025-12-03 23:58:54.000000000","tz":-480},"committer":{"name":"Tim Burke","email":"tim.burke@gmail.com","date":"2026-01-12 17:56:26.000000000","tz":-480},"subject":"Add optional check_reconstruct_fragments function","message":"Add optional check_reconstruct_fragments function\n\nThis function should return either 0 or -EINSUFFFRAGS and can be used\nas a quick check ahead of actually attempting reconstruction. If not\nprovided, default to checking for at least k fragments.\n\nImplement the new function for flat xor codes so they can reconstruct\nin more cases.\n\nChange-Id: Ifa373e4ef8ef3caedb709c40c2b2bfd6fdf6ff7e\nSigned-off-by: Tim Burke \u003ctim.burke@gmail.com\u003e\n","web_links":[{"name":"gitea","tooltip":"Open in GitWeb","url":"https://opendev.org/openstack/liberasurecode/commit/a87ddc707189795666631005898daf1f43df3967"}],"resolve_conflicts_web_links":[{"name":"gitea","tooltip":"Open in GitWeb","url":"https://opendev.org/openstack/liberasurecode/commit/a87ddc707189795666631005898daf1f43df3967"}]},"branch":"refs/heads/master"}},"requirements":[],"submit_records":[{"rule_name":"gerrit~DefaultSubmitRule","status":"CLOSED","labels":[{"label":"Verified","status":"MAY","applied_by":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]}},{"label":"Code-Review","status":"MAY","applied_by":{"_account_id":7233,"name":"Matthew Oliver","email":"matt@oliver.net.au","username":"mattoliverau"}},{"label":"Workflow","status":"MAY","applied_by":{"_account_id":7233,"name":"Matthew Oliver","email":"matt@oliver.net.au","username":"mattoliverau"}}]}],"submit_requirements":[{"name":"Verified","description":"Verified in gate by CI","status":"SATISFIED","is_legacy":false,"submittability_expression_result":{"expression":"label:Verified\u003dMAX AND -label:Verified\u003dMIN","fulfilled":true,"status":"PASS","passing_atoms":["label:Verified\u003dMAX"],"failing_atoms":["label:Verified\u003dMIN"],"atom_explanations":{}}},{"name":"Code-Review","description":"Code reviewed by core reviewer","status":"SATISFIED","is_legacy":false,"submittability_expression_result":{"expression":"label:Code-Review\u003dMAX AND -label:Code-Review\u003dMIN","fulfilled":true,"status":"PASS","passing_atoms":["label:Code-Review\u003dMAX"],"failing_atoms":["label:Code-Review\u003dMIN"],"atom_explanations":{}}},{"name":"Workflow","description":"Approved for gate by core reviewer","status":"SATISFIED","is_legacy":false,"submittability_expression_result":{"expression":"label:Workflow\u003dMAX AND -label:Workflow\u003dMIN","fulfilled":true,"status":"PASS","passing_atoms":["label:Workflow\u003dMAX"],"failing_atoms":["label:Workflow\u003dMIN"],"atom_explanations":{}}}]}
