diff options
| author | Pietro Gagliardi <[email protected]> | 2018-08-11 16:18:01 -0400 |
|---|---|---|
| committer | Pietro Gagliardi <[email protected]> | 2018-08-11 16:18:01 -0400 |
| commit | 308e253e0f7873710bf77312d7a12c576aaa9781 (patch) | |
| tree | fd20704da886ce82a3621ec1502897a8766b11be /AAA_GOFILES/util.go | |
| parent | 0f75ebb5fa7a12bd1df26622ed3f5544a9d1d32b (diff) | |
Moved the existing .go files out of the way and replaced ui.h with the alpha4 ui.h.
Diffstat (limited to 'AAA_GOFILES/util.go')
| -rw-r--r-- | AAA_GOFILES/util.go | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/AAA_GOFILES/util.go b/AAA_GOFILES/util.go new file mode 100644 index 0000000..b097004 --- /dev/null +++ b/AAA_GOFILES/util.go @@ -0,0 +1,53 @@ +// 12 december 2015 + +package ui + +import ( + "unsafe" +) + +// #include <stdlib.h> +// // TODO remove when switching to Go 1.7 +// #include <string.h> +import "C" + +// TODO move this to C.CBytes() when switching to Go 1.7 + +// 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 ZeroMemory() +// for free. +var uimallocBytes = make([]byte, 1024) // 1024 bytes first + +//export uimalloc +func uimalloc(n C.size_t) unsafe.Pointer { + if n > C.size_t(len(uimallocBytes)) { + // TODO round n up to a multiple of a power of 2? + // for instance 0x1234 bytes -> 0x1800 bytes + uimallocBytes = make([]byte, n) + } + p := C.malloc(n) + if p == nil { + panic("out of memory in uimalloc()") + } + C.memset(p, 0, n) + return p +} + +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 +} |
