shithub: mc

ref: 3cdb85952401e2284ecd285742174b8f774bf18b
dir: /lib/std/test/sort.myr/

View raw version
use std

const main = {
	var i

	var a = [ 3, 5, 4, 9, 7, 2, 6, 0, 1, 8, ]
	var a_sorted = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
	var b = [3, 4, 5, 1, 2, 6, 7, 8, 9, 10]
	var b_sorted = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
	var c = ["a", "aa", "b", "C", "Cc", "cC", "d", "f", "fuckit", "go",]
	var c_sorted = ["C", "Cc", "a", "aa", "b", "cC", "d", "f", "fuckit", "go"]

	/* with custom intcmp */
	std.sort(a[:], intcmp)
	std.assert(std.sleq(a[:], a_sorted[:]), "a was missorted")

	/* with libstd generic numcmp */
	std.sort(b[:], std.numcmp)
	std.assert(std.sleq(b[:], b_sorted[:]), "b was missorted")

	/* string sorting */
	std.sort(c[:], std.strcmp)
	for i = 0; i < c.len; i++
		std.assert(std.sleq(c[i], c_sorted[i]), "c was missorted")
	;;
}

const intcmp = {a, b
	if a < b
		-> `std.Before
	elif a == b
		-> `std.Equal
	else
		-> `std.After
	;;
}