Blame test/sortu.awk

Packit Service f629e6
# numeric before string, ascending by index
Packit Service f629e6
function comp_num_str(s1, v1, s2, v2,		n1, n2) {
Packit Service f629e6
	n1 = s1 + 0
Packit Service f629e6
	n2 = s2 + 0
Packit Service f629e6
	if (n1 == s1)
Packit Service f629e6
		return (n2 == s2) ? (n1 - n2) : -1
Packit Service f629e6
	else if (n2 == s2)
Packit Service f629e6
		return 1
Packit Service f629e6
	return (s1 < s2) ? -1 : (s1 != s2)
Packit Service f629e6
}
Packit Service f629e6
Packit Service f629e6
# ascending index number
Packit Service f629e6
function comp_idx_num(s1, v1, s2, v2)
Packit Service f629e6
{
Packit Service f629e6
	return (s1 - s2)
Packit Service f629e6
}
Packit Service f629e6
Packit Service f629e6
# ascending value number
Packit Service f629e6
function comp_val_num(s1, v1, s2, v2,	num)
Packit Service f629e6
{
Packit Service f629e6
	num = "^[-+]?([0-9]+[.]?[0-9]*|[.][0-9]+)([eE][-+]?[0-9]+)?$"
Packit Service f629e6
	# force stable sort, compare as strings if not numeric
Packit Service f629e6
	if ((v1 - v2) == 0 && (v1 !~ num || v2 !~ num))
Packit Service f629e6
		return comp_val_str(s1, v1, s2, v2)
Packit Service f629e6
	return (v1 - v2)
Packit Service f629e6
}
Packit Service f629e6
Packit Service f629e6
# ascending value string
Packit Service f629e6
function comp_val_str(s1, v1, s2, v2)
Packit Service f629e6
{
Packit Service f629e6
	v1 = v1 ""
Packit Service f629e6
	v2 = v2 ""
Packit Service f629e6
	return (v1 < v2) ? -1 : (v1 != v2)
Packit Service f629e6
}
Packit Service f629e6
Packit Service f629e6
# deterministic, by value (and index), descending numeric
Packit Service f629e6
function comp_val_idx(s1, v1, s2, v2)
Packit Service f629e6
{
Packit Service f629e6
	return (v1 != v2) ? (v2 - v1) : (s2 - s1)
Packit Service f629e6
}
Packit Service f629e6
Packit Service f629e6
BEGIN {
Packit Service f629e6
	a[1] = 10; a[100] = 1; a[2] = 200
Packit Service f629e6
	a["cat"] = "tac"; a["rat"] = "tar";a["bat"] = "tab"
Packit Service f629e6
Packit Service f629e6
	print "--- number before string, ascending by index ---"
Packit Service f629e6
	PROCINFO["sorted_in"] = "comp_num_str"
Packit Service f629e6
	for (i in a)
Packit Service f629e6
		printf("%-10s%-s\n", i, a[i])
Packit Service f629e6
Packit Service f629e6
	delete a
Packit Service f629e6
	a[11] = 10; a[100] = 5; a[2] = 200
Packit Service f629e6
	a[4] = 1; a[20] = 10; a[14] = 10
Packit Service f629e6
	print "--- deterministic, by value (index), descending numeric ---"
Packit Service f629e6
	PROCINFO["sorted_in"] = "comp_val_idx"
Packit Service f629e6
	for (i in a)
Packit Service f629e6
		printf("%-10s%-s\n", i, a[i])
Packit Service f629e6
Packit Service f629e6
	for (IGNORECASE=0; IGNORECASE <= 1; IGNORECASE++) {
Packit Service f629e6
		makea(a)
Packit Service f629e6
		SORT_STR =  "comp_val_num"
Packit Service f629e6
		printf("--- asort(a, b, \"%s\"), IGNORECASE = %d---\n", SORT_STR, IGNORECASE)
Packit Service f629e6
		asort2(a, "")
Packit Service f629e6
Packit Service f629e6
		makea(a)
Packit Service f629e6
		SORT_STR =  "comp_val_str"
Packit Service f629e6
		printf("--- asort(a, b, \"%s\"), IGNORECASE = %d---\n", SORT_STR, IGNORECASE)
Packit Service f629e6
		asort2(a, "")
Packit Service f629e6
Packit Service f629e6
		makea(a)
Packit Service f629e6
		SORT_STR = "comp_val_str"
Packit Service f629e6
		printf("--- asort(a, a, \"%s\"), IGNORECASE = %d---\n", SORT_STR, IGNORECASE)
Packit Service f629e6
		asort1(a, "")
Packit Service f629e6
  }
Packit Service f629e6
}
Packit Service f629e6
Packit Service f629e6
function makea(aa)
Packit Service f629e6
{
Packit Service f629e6
	delete aa
Packit Service f629e6
	aa[1] = "barz";
Packit Service f629e6
	aa[2] = "blattt";
Packit Service f629e6
	aa[3] = "Zebra";
Packit Service f629e6
	aa[4] = 1234;
Packit Service f629e6
	aa[5] = 234;
Packit Service f629e6
}
Packit Service f629e6
Packit Service f629e6
# source array != destination array 
Packit Service f629e6
function asort2(c, s,	d, k, m) 
Packit Service f629e6
{
Packit Service f629e6
	if (SORT_STR < 0)
Packit Service f629e6
		m = asort(c, d);
Packit Service f629e6
	else
Packit Service f629e6
		m = asort(c, d, SORT_STR);
Packit Service f629e6
	for (k=1; k <= m; k++) {
Packit Service f629e6
		if (isarray(d[k]))
Packit Service f629e6
			asort2(d[k], s"["k"]")
Packit Service f629e6
		else
Packit Service f629e6
			printf("%-10s:%-10s%-10s\n", s"["k"]", c[k], d[k])
Packit Service f629e6
	}
Packit Service f629e6
}
Packit Service f629e6
Packit Service f629e6
# source array == destination array
Packit Service f629e6
function asort1(c, s,   k, m) 
Packit Service f629e6
{
Packit Service f629e6
	if (SORT_STR < 0)
Packit Service f629e6
		m = asort(c)
Packit Service f629e6
	else if (SORT_STR != "")
Packit Service f629e6
		m = asort(c, c, SORT_STR)
Packit Service f629e6
	else
Packit Service f629e6
		m = asort(c, c);
Packit Service f629e6
Packit Service f629e6
	for (k=1; k <= m; k++) {
Packit Service f629e6
		if (isarray(c[k]))
Packit Service f629e6
			asort1(c[k], s"["k"]")
Packit Service f629e6
		else
Packit Service f629e6
			printf("%-10s:%-10s\n", s"["k"]", c[k])
Packit Service f629e6
	}
Packit Service f629e6
}