From c66203d984fbdcc89efb53e4408bc4534253f015 Mon Sep 17 00:00:00 2001 From: mappu Date: Wed, 16 Oct 2024 19:01:54 +1300 Subject: [PATCH] genbindings/go: return C char* as string --- cmd/genbindings/emitgo.go | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/cmd/genbindings/emitgo.go b/cmd/genbindings/emitgo.go index 229928cc..d93bac1b 100644 --- a/cmd/genbindings/emitgo.go +++ b/cmd/genbindings/emitgo.go @@ -329,7 +329,7 @@ func (gfs *goFileState) emitParameterGo2CABIForwarding(p CppParameter) (preamble func (gfs *goFileState) emitCabiToGo(assignExpr string, rt CppParameter, rvalue string) string { - shouldReturn := "return " + shouldReturn := assignExpr // "return " afterword := "" namePrefix := makeNamePrefix(rt.ParameterName) @@ -343,10 +343,16 @@ func (gfs *goFileState) emitCabiToGo(assignExpr string, rt CppParameter, rvalue // Qt functions normally return QString - anything returning char* // is something like QByteArray.Data() where it returns an unsafe // internal pointer + // However in case this is a signal, we need to be able to marshal both + // forwards and backwards with the same types, this has to be a string + // in both cases + // This is not a miqt_string and therefore MIQT did not allocate it, + // and therefore we don't have to free it either gfs.imports["unsafe"] = struct{}{} shouldReturn = namePrefix + "_ret := " - afterword += assignExpr + " (unsafe.Pointer)(" + namePrefix + "_ret)\n" + afterword += assignExpr + " C.GoString(" + namePrefix + "_ret)\n" + return shouldReturn + " " + rvalue + "\n" + afterword } else if rt.ParameterType == "QString" { gfs.imports["unsafe"] = struct{}{}