shithub: mc

ref: 5c11d9f0c97f8b466597c680e1178a61c676c489
dir: /libstd/hashfuncs.myr/

View raw version
use "sleq.use"
use "types.use"

pkg std =
	const strhash	: (s : byte[:]	-> uint32)
	const streq	: (a : byte[:], b : byte[:]	-> bool)

	generic ptrhash	: (p : @a#	-> uint32)
	generic ptreq	: (a : @a#, b : @a#	-> bool)

	generic inthash	: (v : @a::(tcint,tcnum,tctest)	-> uint32)
	generic inteq	: (a : @a::(tcint,tcnum,tctest), b : @a::(tcint,tcnum,tctest) -> bool)
;;

/* Supremely simple djb hash. */
const strhash = {s
	var h
	
	h = 5381
	for b in s
		h = (h << 5) + h + (b castto(uint32))
	;;
	-> h
}

const streq = {a, b
	-> sleq(a, b)
}

/* FIXME: come up with a *good* hash function */
generic ptrhash = {p
	var x

	x = p castto(intptr)
	/* Mix the top bits in to the bottom, and multiply by a large prime. */
	x = x ^ (x >> 32) * 357913941	
	-> x castto(uint32)
}

generic ptreq = {a, b
	-> a == b
}

/* FIXME: come up with a *good* hash function */
generic inthash = {v
	var x

	x = v castto(uint64)
	/* Mix the top bits in to the bottom, and multiply by a large prime. */
	x = x ^ (x >> 32) * 357913941	
	-> x castto(uint32)
}

generic inteq = {a, b
	-> a == b
}