mirror of
https://github.com/mappu/miqt.git
synced 2025-01-05 07:08:39 +00:00
genbindings: s/renderTypeCpp/Cabi
This commit is contained in:
parent
306abe1fb6
commit
c59545c956
@ -6,7 +6,7 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (p CppParameter) RenderTypeCpp() string {
|
func (p CppParameter) RenderTypeCabi() string {
|
||||||
ret := p.ParameterType
|
ret := p.ParameterType
|
||||||
switch p.ParameterType {
|
switch p.ParameterType {
|
||||||
case "uchar":
|
case "uchar":
|
||||||
@ -66,7 +66,7 @@ func emitReturnTypeCabi(p CppParameter) string {
|
|||||||
// return "void" // Handled separately with an _out pointer
|
// return "void" // Handled separately with an _out pointer
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
return p.RenderTypeCpp()
|
return p.RenderTypeCabi()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -129,7 +129,7 @@ func emitParametersCabi(m CppMethod, selfType string) string {
|
|||||||
} else {
|
} else {
|
||||||
// The Go code has called this with two arguments: T* and len
|
// The Go code has called this with two arguments: T* and len
|
||||||
// Declare that we take two parameters
|
// Declare that we take two parameters
|
||||||
tmp = append(tmp, t.RenderTypeCpp()+"* "+p.ParameterName+", size_t "+p.ParameterName+"_len")
|
tmp = append(tmp, t.RenderTypeCabi()+"* "+p.ParameterName+", size_t "+p.ParameterName+"_len")
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if (p.ByRef || p.Pointer) && p.QtClassType() {
|
} else if (p.ByRef || p.Pointer) && p.QtClassType() {
|
||||||
@ -144,8 +144,8 @@ func emitParametersCabi(m CppMethod, selfType string) string {
|
|||||||
tmp = append(tmp, p.ParameterType+"* "+p.ParameterName)
|
tmp = append(tmp, p.ParameterType+"* "+p.ParameterName)
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
// RenderTypeCpp renders both pointer+reference as pointers
|
// RenderTypeCabi renders both pointer+reference as pointers
|
||||||
tmp = append(tmp, p.RenderTypeCpp()+" "+p.ParameterName)
|
tmp = append(tmp, p.RenderTypeCabi()+" "+p.ParameterName)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -170,9 +170,9 @@ func emitParametersCabi(m CppMethod, selfType string) string {
|
|||||||
} else if t.QtClassType() && !t.Pointer {
|
} else if t.QtClassType() && !t.Pointer {
|
||||||
// QList<QByteArray> QByteArray::Split()
|
// QList<QByteArray> QByteArray::Split()
|
||||||
// We need to pointer-ify each of the interior elements too
|
// We need to pointer-ify each of the interior elements too
|
||||||
tmp = append(tmp, t.RenderTypeCpp()+"*** _out, size_t* _out_len")
|
tmp = append(tmp, t.RenderTypeCabi()+"*** _out, size_t* _out_len")
|
||||||
} else {
|
} else {
|
||||||
tmp = append(tmp, t.RenderTypeCpp()+"** _out, size_t* _out_len")
|
tmp = append(tmp, t.RenderTypeCabi()+"** _out, size_t* _out_len")
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -216,7 +216,7 @@ func emitParametersCABI2CppForwarding(params []CppParameter) (preamble string, f
|
|||||||
|
|
||||||
} else if p.IntType() {
|
} else if p.IntType() {
|
||||||
// Use the raw ParameterType to select an explicit integer overload
|
// Use the raw ParameterType to select an explicit integer overload
|
||||||
// Don't use RenderTypeCpp() since it canonicalizes some int types for CABI
|
// Don't use RenderTypeCabi() since it canonicalizes some int types for CABI
|
||||||
castSrc := p.ParameterName
|
castSrc := p.ParameterName
|
||||||
castType := p.ParameterType
|
castType := p.ParameterType
|
||||||
if p.Pointer {
|
if p.Pointer {
|
||||||
@ -236,7 +236,7 @@ func emitParametersCABI2CppForwarding(params []CppParameter) (preamble string, f
|
|||||||
tmp = append(tmp, "static_cast<"+castType+">("+castSrc+")")
|
tmp = append(tmp, "static_cast<"+castType+">("+castSrc+")")
|
||||||
|
|
||||||
} else if p.ByRef {
|
} else if p.ByRef {
|
||||||
// We changed RenderTypeCpp() to render this as a pointer
|
// We changed RenderTypeCabi() to render this as a pointer
|
||||||
// Need to dereference so we can pass as reference to the actual Qt C++ function
|
// Need to dereference so we can pass as reference to the actual Qt C++ function
|
||||||
//tmp = append(tmp, "*"+p.ParameterName)
|
//tmp = append(tmp, "*"+p.ParameterName)
|
||||||
tmp = append(tmp, "*"+p.ParameterName)
|
tmp = append(tmp, "*"+p.ParameterName)
|
||||||
@ -487,7 +487,7 @@ extern "C" {
|
|||||||
|
|
||||||
shouldReturn = m.ReturnType.ParameterType + " ret = "
|
shouldReturn = m.ReturnType.ParameterType + " ret = "
|
||||||
afterCall += "\t// Convert QList<> from C++ memory to manually-managed C memory\n"
|
afterCall += "\t// Convert QList<> from C++ memory to manually-managed C memory\n"
|
||||||
afterCall += "\t" + t.RenderTypeCpp() + "* __out = static_cast<" + t.RenderTypeCpp() + "*>(malloc(sizeof(" + t.RenderTypeCpp() + ") * ret.length()));\n"
|
afterCall += "\t" + t.RenderTypeCabi() + "* __out = static_cast<" + t.RenderTypeCabi() + "*>(malloc(sizeof(" + t.RenderTypeCabi() + ") * ret.length()));\n"
|
||||||
afterCall += "\tfor (size_t i = 0, e = ret.length(); i < e; ++i) {\n"
|
afterCall += "\tfor (size_t i = 0, e = ret.length(); i < e; ++i) {\n"
|
||||||
afterCall += "\t\t__out[i] = ret[i];\n"
|
afterCall += "\t\t__out[i] = ret[i];\n"
|
||||||
afterCall += "\t}\n"
|
afterCall += "\t}\n"
|
||||||
@ -498,7 +498,7 @@ extern "C" {
|
|||||||
|
|
||||||
shouldReturn = m.ReturnType.ParameterType + " ret = "
|
shouldReturn = m.ReturnType.ParameterType + " ret = "
|
||||||
afterCall += "\t// Convert QList<> from C++ memory to manually-managed C memory of copy-constructed pointers\n"
|
afterCall += "\t// Convert QList<> from C++ memory to manually-managed C memory of copy-constructed pointers\n"
|
||||||
afterCall += "\t" + t.RenderTypeCpp() + "** __out = static_cast<" + t.RenderTypeCpp() + "**>(malloc(sizeof(" + t.RenderTypeCpp() + "**) * ret.length()));\n"
|
afterCall += "\t" + t.RenderTypeCabi() + "** __out = static_cast<" + t.RenderTypeCabi() + "**>(malloc(sizeof(" + t.RenderTypeCabi() + "**) * ret.length()));\n"
|
||||||
afterCall += "\tfor (size_t i = 0, e = ret.length(); i < e; ++i) {\n"
|
afterCall += "\tfor (size_t i = 0, e = ret.length(); i < e; ++i) {\n"
|
||||||
afterCall += "\t\t__out[i] = new " + t.ParameterType + "(ret[i]);\n"
|
afterCall += "\t\t__out[i] = new " + t.ParameterType + "(ret[i]);\n"
|
||||||
afterCall += "\t}\n"
|
afterCall += "\t}\n"
|
||||||
|
@ -109,7 +109,7 @@ func (p CppParameter) parameterTypeCgo() string {
|
|||||||
if p.ParameterType == "QString" {
|
if p.ParameterType == "QString" {
|
||||||
return "C.char"
|
return "C.char"
|
||||||
}
|
}
|
||||||
tmp := strings.Replace(p.RenderTypeCpp(), `*`, "", -1)
|
tmp := strings.Replace(p.RenderTypeCabi(), `*`, "", -1)
|
||||||
if strings.HasPrefix(tmp, "unsigned ") {
|
if strings.HasPrefix(tmp, "unsigned ") {
|
||||||
tmp = "u" + tmp[9:] // Cgo uses uchar, uint instead of full name
|
tmp = "u" + tmp[9:] // Cgo uses uchar, uint instead of full name
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user