2015-12-12 12:07:57 -06:00
|
|
|
// 12 december 2015
|
|
|
|
|
|
|
|
package ui
|
|
|
|
|
|
|
|
import (
|
|
|
|
"unsafe"
|
|
|
|
)
|
|
|
|
|
|
|
|
// #include <stdlib.h>
|
2018-08-12 09:24:24 -05:00
|
|
|
// #include "util.h"
|
2015-12-12 12:07:57 -06:00
|
|
|
import "C"
|
|
|
|
|
2016-04-12 22:27:29 -05:00
|
|
|
// 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
|
2018-08-12 09:24:24 -05:00
|
|
|
// that's always initialized to zero gives us the memset(0)
|
|
|
|
// (or ZeroMemory()) for free.
|
|
|
|
var allocBytes = make([]byte, 1024) // 1024 bytes first
|
2016-04-12 22:27:29 -05:00
|
|
|
|
2018-08-12 09:24:24 -05:00
|
|
|
//export pkguiAlloc
|
|
|
|
func pkguiAlloc(n C.size_t) unsafe.Pointer {
|
|
|
|
if n > C.size_t(len(allocBytes)) {
|
2016-04-12 22:27:29 -05:00
|
|
|
// TODO round n up to a multiple of a power of 2?
|
|
|
|
// for instance 0x1234 bytes -> 0x1800 bytes
|
2018-08-12 09:24:24 -05:00
|
|
|
allocBytes = make([]byte, n)
|
2016-04-12 18:17:59 -05:00
|
|
|
}
|
2018-08-12 09:24:24 -05:00
|
|
|
return C.CBytes(allocBytes[:n])
|
2016-04-12 18:17:59 -05:00
|
|
|
}
|
|
|
|
|
2015-12-12 12:07:57 -06:00
|
|
|
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
|
|
|
|
}
|