shithub: mc

Download patch

ref: bd225cf9a9ec5a2d3bd35c067d011729d8fb9ae0
parent: aa419bde150ce4827ec127288876ce2d0a191629
author: Ori Bernstein <ori@eigenstate.org>
date: Wed Jul 1 17:36:02 EDT 2015

Add format funcs.

--- a/libstd/bigint.myr
+++ b/libstd/bigint.myr
@@ -27,7 +27,6 @@
 	const bigmove	: (d : bigint#, s : bigint# -> bigint#)
 	const bigparse	: (s : byte[:] -> option(bigint#))
 	const bigclear	: (a : bigint# -> bigint#)
-	const bigfmt	: (a : bigint#, base : int -> byte[:])
 	const bigbfmt	: (b : byte[:], a : bigint#, base : int -> size)
 	/*
 	const bigtoint	: (a : bigint#	-> @a::(numeric,integral))
@@ -115,25 +114,6 @@
 	v.sign = 0
 	v.dig = [][:]
 	-> v
-}
-
-const bigfmt = {a, base
-	var buf
-	var n
-
- 	/*
-	allocate a buffer guaranteed to be big enough.
-	that's 
-		2 + floor(nbits/(log_2(10)))
-	or
-		2 + a.dig.len * 32/3.32...
-	or
-		2 + a.dig.len * 10
-	plus one for the - sign.
-	*/
-	buf = slalloc(3 + a.dig.len * 10)
-	n = bigbfmt(buf, a, base)
-	-> buf[:n]
 }
 
 /* for now, just dump out something for debugging... */
--- a/libstd/bld.sub
+++ b/libstd/bld.sub
@@ -40,6 +40,7 @@
 	fltbits.myr
 	fltfmt.myr
         fmt.myr
+	fmtfuncs.myr
 	getcwd.myr
 	getint.myr
 	hashfuncs.myr
--- /dev/null
+++ b/libstd/fmtfuncs.myr
@@ -1,0 +1,54 @@
+use "alloc.use"
+use "bigint.use"
+use "bitset.use"
+use "fmt.use"
+use "introspect.use"
+use "strbuf.use"
+use "varargs.use"
+
+pkg std =
+;;
+
+const __init__ = {
+	var bigint : bigint#
+	var bitset : bitset#
+
+	fmtinstall(typeof(bigint), bigfmt, [][:])
+	fmtinstall(typeof(bitset), bsfmt, [][:])
+}
+
+const bigfmt = {sb, ap, opts
+	var a, n, buf
+
+	a = vanext(ap)
+ 	/*
+	allocate a buffer guaranteed to be big enough.
+	that's 
+		2 + floor(nbits/(log_2(10)))
+	or
+		2 + a.dig.len * 32/3.32...
+	or
+		2 + a.dig.len * 10
+	plus one for the - sign.
+	*/
+	buf = slalloc(3 + a.dig.len * 10)
+	n = bigbfmt(buf, a, 10)
+	sbputs(sb, buf[:n])
+	slfree(buf)
+}
+
+const bsfmt = {sb, ap, opts
+	var i, bs
+
+	bs = vanext(ap)
+	sbputs(sb, "bitset{")
+	for i = 0; i < bsmax(bs); i++
+		if bshas(bs, i)
+			if i != 0
+				sbfmt(sb, ", ")
+			;;
+			sbfmt(sb, "{}", i)
+		;;
+	;;
+	sbputs(sb, "}")
+}