aboutsummaryrefslogtreecommitdiff
path: root/netaddr.go
diff options
context:
space:
mode:
authorDeterminant <ted.sybil@gmail.com>2019-06-16 23:27:05 -0400
committerDeterminant <ted.sybil@gmail.com>2019-06-16 23:27:05 -0400
commit3ba5b6536e730baf01efb3203be280c3e61319bd (patch)
treed07fd2d8f2e8db1fcfe5a14be38ba2fbf87a9075 /netaddr.go
parent63e3f71d4d6bed69b99bebc9866d1214837259f6 (diff)
eliminate the use of Free()
Diffstat (limited to 'netaddr.go')
-rw-r--r--netaddr.go51
1 files changed, 34 insertions, 17 deletions
diff --git a/netaddr.go b/netaddr.go
index a631689..ab261b5 100644
--- a/netaddr.go
+++ b/netaddr.go
@@ -3,33 +3,50 @@ package salticidae
// #include <stdlib.h>
// #include "salticidae/netaddr.h"
import "C"
+import "runtime"
-type NetAddr = *C.netaddr_t
-type NetAddrArray = *C.netaddr_array_t
+type netAddr struct {
+ inner *C.netaddr_t
+}
+
+type NetAddr = *netAddr
+
+type netAddrArray struct {
+ inner *C.netaddr_array_t
+}
+
+type NetAddrArray = *netAddrArray
func NewAddrFromIPPortString(addr string) (res NetAddr) {
c_str := C.CString(addr)
- res = C.netaddr_new_from_sipport(c_str)
+ res = &netAddr{ inner: C.netaddr_new_from_sipport(c_str) }
C.free(rawptr_t(c_str))
+ runtime.SetFinalizer(res, func(self NetAddr) { self.free() })
return
}
-func (self NetAddr) Free() { C.netaddr_free(self) }
-
-func (self NetAddr) IsEq(other NetAddr) bool { return bool(C.netaddr_is_eq(self, other)) }
-
-func (self NetAddr) IsNull() bool { return bool(C.netaddr_is_null(self)) }
-
-func (self NetAddr) GetIP() uint32 { return uint32(C.netaddr_get_ip(self)) }
-
-func (self NetAddr) GetPort() uint16 { return uint16(C.netaddr_get_port(self)) }
-
-func NewAddrArrayFromAddrs(arr []NetAddr) NetAddrArray {
+func NewAddrArrayFromAddrs(arr []NetAddr) (res NetAddrArray) {
size := len(arr)
if size > 0 {
- base := (**C.netaddr_t)(&arr[0])
- return C.netaddr_array_new_from_addrs(base, C.size_t(size))
+ // FIXME: here we assume struct of a single pointer has the same memory
+ // footprint the pointer
+ base := (**C.netaddr_t)(rawptr_t(&arr[0]))
+ res = &netAddrArray{ inner: C.netaddr_array_new_from_addrs(base, C.size_t(size)) }
} else {
- return C.netaddr_array_new()
+ res = &netAddrArray{ inner: C.netaddr_array_new() }
}
+ runtime.SetFinalizer(res, func(self NetAddrArray) { self.free() })
+ return
}
+
+func (self NetAddr) free() { C.netaddr_free(self.inner) }
+
+func (self NetAddr) IsEq(other NetAddr) bool { return bool(C.netaddr_is_eq(self.inner, other.inner)) }
+
+func (self NetAddr) IsNull() bool { return bool(C.netaddr_is_null(self.inner)) }
+
+func (self NetAddr) GetIP() uint32 { return uint32(C.netaddr_get_ip(self.inner)) }
+
+func (self NetAddr) GetPort() uint16 { return uint16(C.netaddr_get_port(self.inner)) }
+
+func (self NetAddrArray) free() { C.netaddr_array_free(self.inner) }