don't free memory that we want to read later

master
Jordan Orelli 8 years ago
parent 5cedb973de
commit 9ce7bcefe6

@ -2,7 +2,6 @@ package ui
import ( import (
"log" "log"
"unsafe"
"github.com/jordanorelli/dws/events" "github.com/jordanorelli/dws/events"
) )
@ -50,26 +49,21 @@ func (ui *cocoaUI) forwardEvent(e events.BackgroundEvent) {
case events.SetRootEvent: case events.SetRootEvent:
cpath := C.CString(v.Path) cpath := C.CString(v.Path)
defer C.free(unsafe.Pointer(cpath))
C.bg_set_root(cpath) C.bg_set_root(cpath)
case events.BeginRequestEvent: case events.BeginRequestEvent:
cpath := C.CString(v.Path) cpath := C.CString(v.Path)
defer C.free(unsafe.Pointer(cpath)) req := (*C.struct_RequestMeta)(C.malloc(C.sizeof_struct_RequestMeta))
req.seq = C.int(v.Seq)
req := &C.struct_RequestMeta{ req.path = cpath
seq: C.int(v.Seq),
path: cpath,
}
C.bg_received_request(req) C.bg_received_request(req)
case events.EndRequestEvent: case events.EndRequestEvent:
C.bg_sent_response(&C.struct_ResponseMeta{ res := (*C.struct_ResponseMeta)(C.malloc(C.sizeof_struct_ResponseMeta))
seq: C.int(v.Seq), res.seq = C.int(v.Seq)
status: C.int(v.Status), res.status = C.int(v.Status)
bytes: C.int(v.Bytes), res.bytes = C.int(v.Bytes)
}) C.bg_sent_response(res)
} }
} }

@ -26,6 +26,7 @@ void bg_shutdown() {
void bg_set_root(char *path) { void bg_set_root(char *path) {
id listener = [[EventBridge shared] listener]; id listener = [[EventBridge shared] listener];
[listener serverDidSetRoot:[NSString stringWithUTF8String:path]]; [listener serverDidSetRoot:[NSString stringWithUTF8String:path]];
free(path);
} }
void bg_received_request(RequestMeta *meta) { void bg_received_request(RequestMeta *meta) {

Loading…
Cancel
Save