summaryrefslogtreecommitdiff
path: root/util.go
diff options
context:
space:
mode:
authorPietro Gagliardi <[email protected]>2018-08-12 10:24:24 -0400
committerPietro Gagliardi <[email protected]>2018-08-12 10:24:24 -0400
commitcfea745dc745dcb0af8704d7cdb50d9725714b04 (patch)
tree08b0f37d5fd7379bb2c55a2f5a703d4d8498e640 /util.go
parent8d43eb52cef37f870c469224b30ea23bec48c3f1 (diff)
Migrated util.go back and formalized pkguiAlloc().
Diffstat (limited to 'util.go')
-rw-r--r--util.go45
1 files changed, 45 insertions, 0 deletions
diff --git a/util.go b/util.go
new file mode 100644
index 0000000..bcd4d33
--- /dev/null
+++ b/util.go
@@ -0,0 +1,45 @@
+// 12 december 2015
+
+package ui
+
+import (
+ "unsafe"
+)
+
+// #include <stdlib.h>
+// #include "util.h"
+import "C"
+
+// We want Go itself to complain when we're out of memory.
+// The allocators in cgo *should* do this, but there isn't a
+// C.CMalloc(). There *is* a C.CBytes(), however, for transferring
+// binary blobs from Go to C. If we pass this an arbitrary slice
+// of the desired length, we get our C.CMalloc(). Using a slice
+// that's always initialized to zero gives us the memset(0)
+// (or ZeroMemory()) for free.
+var allocBytes = make([]byte, 1024) // 1024 bytes first
+
+//export pkguiAlloc
+func pkguiAlloc(n C.size_t) unsafe.Pointer {
+ if n > C.size_t(len(allocBytes)) {
+ // TODO round n up to a multiple of a power of 2?
+ // for instance 0x1234 bytes -> 0x1800 bytes
+ allocBytes = make([]byte, n)
+ }
+ return C.CBytes(allocBytes[:n])
+}
+
+func freestr(str *C.char) {
+ C.free(unsafe.Pointer(str))
+}
+
+func tobool(b C.int) bool {
+ return b != 0
+}
+
+func frombool(b bool) C.int {
+ if b {
+ return 1
+ }
+ return 0
+}