shithub: mc

Download patch

ref: b24fd14c329aa00b0d9703864f875258164216c4
parent: b0556e8d98eb7ab7cdc0826de7cdcfcef935db82
author: andrewchambers <[email protected]>
date: Sat Jul 23 11:59:21 EDT 2016

make bsearch use unsigned indexes (#118)


--- a/lib/std/search.myr
+++ b/lib/std/search.myr
@@ -1,5 +1,6 @@
 use "cmp"
 use "option"
+use "types"
 
 pkg std =
 	generic lsearch	: (sl : @t[:], key : @k, cmp : (v : @t, k : @k -> order) -> option(@idx::(integral,numeric)))
@@ -21,7 +22,7 @@
 
 /* binary search over a sorted list of values. */
 generic bsearch  = {sl, key, cmp
-	var hi, lo, mid
+	var hi, lo, mid : usize
 
 	lo = 0
 	hi = sl.len - 1
@@ -32,7 +33,7 @@
 		| `After:	hi = mid - 1
 		| `Before:	lo = mid + 1
 		| `Equal:	
-			-> `Some mid
+			-> `Some (mid : @idx)
 		;;
 	;;
 	-> `None
--- a/lib/std/types.myr
+++ b/lib/std/types.myr
@@ -2,7 +2,7 @@
 
 pkg std =
 	type size	= sys.size	/* spans entire address space */
-	type usize	= sys.usize	/* signed size */
+	type usize	= sys.usize	/* unsigned size */
 	type off	= sys.off	/* file offsets */
 	type intptr	= sys.intptr	/* can hold any pointer losslessly */
 	type time	= sys.time	/* milliseconds since epoch */
--- a/lib/sys/systypes.myr
+++ b/lib/sys/systypes.myr
@@ -1,6 +1,6 @@
 pkg sys =
 	type size	= int64	/* spans entire address space */
-	type usize	= int64	/* signed size */
+	type usize	= uint64	/* unsigned size */
 	type off	= int64	/* file offsets */
 	type intptr	= uint64/* can hold any pointer losslessly */
 	type time	= int64	/* milliseconds since epoch */