bin/refs: Sort listing

The output is much more readable sorted. I can't think of any reason
you'd want it unsorted (which is essentially dentry order).
This commit is contained in:
Dan Nicholson 2023-01-29 06:49:18 -07:00
parent 2b8707b010
commit 6b0f42ae37
2 changed files with 32 additions and 6 deletions

View File

@ -47,6 +47,16 @@ static GOptionEntry options[] = {
{ NULL } { NULL }
}; };
static int
collection_ref_cmp (OstreeCollectionRef *a,
OstreeCollectionRef *b)
{
int ret = g_strcmp0 (a->collection_id, b->collection_id);
if (ret == 0)
ret = g_strcmp0 (a->ref_name, b->ref_name);
return ret;
}
static gboolean static gboolean
do_ref_with_collections (OstreeRepo *repo, do_ref_with_collections (OstreeRepo *repo,
const char *refspec_prefix, const char *refspec_prefix,
@ -66,10 +76,12 @@ do_ref_with_collections (OstreeRepo *repo,
if (!opt_delete && !opt_create) if (!opt_delete && !opt_create)
{ {
g_hash_table_iter_init (&hashiter, refs); g_autoptr(GList) ordered_keys = g_hash_table_get_keys (refs);
while (g_hash_table_iter_next (&hashiter, &hashkey, &hashvalue)) ordered_keys = g_list_sort (ordered_keys, (GCompareFunc) collection_ref_cmp);
for (GList *iter = ordered_keys; iter != NULL; iter = iter->next)
{ {
const OstreeCollectionRef *ref = hashkey; OstreeCollectionRef *ref = iter->data;
g_print ("(%s, %s)\n", ref->collection_id, ref->ref_name); g_print ("(%s, %s)\n", ref->collection_id, ref->ref_name);
} }
} }
@ -179,12 +191,22 @@ static gboolean do_ref (OstreeRepo *repo, const char *refspec_prefix, GCancellab
if (is_list) if (is_list)
{ {
GLNX_HASH_TABLE_FOREACH_KV (refs, const char *, ref, const char *, value) g_autoptr(GList) ordered_keys = g_hash_table_get_keys (refs);
ordered_keys = g_list_sort (ordered_keys, (GCompareFunc) g_strcmp0);
for (GList *iter = ordered_keys; iter != NULL; iter = iter->next)
{ {
const char *ref = iter->data;
if (opt_alias) if (opt_alias)
g_print ("%s -> %s\n", ref, value); {
const char *alias = g_hash_table_lookup (refs, ref);
g_print ("%s -> %s\n", ref, alias);
}
else else
g_print ("%s\n", ref); {
g_print ("%s\n", ref);
}
} }
} }
else if (opt_create) else if (opt_create)

View File

@ -42,6 +42,10 @@ done
${CMD_PREFIX} ostree --repo=repo refs | wc -l > refscount ${CMD_PREFIX} ostree --repo=repo refs | wc -l > refscount
assert_file_has_content refscount "^10$" assert_file_has_content refscount "^10$"
${CMD_PREFIX} ostree --repo=repo refs > refs
sort refs > refs-sorted
assert_files_equal refs refs-sorted
${CMD_PREFIX} ostree --repo=repo refs foo > refs ${CMD_PREFIX} ostree --repo=repo refs foo > refs
assert_not_file_has_content refs foo assert_not_file_has_content refs foo