mirror of
https://github.com/mappu/miqt.git
synced 2025-01-08 16:38:37 +00:00
genbindings: public/private visibility support
This commit is contained in:
parent
7319683a3f
commit
60d5aa55d1
@ -44,7 +44,15 @@ func parseHeader(inner []interface{}) (*parsedHeader, error) {
|
|||||||
|
|
||||||
fmt.Printf("-> %q name=%q\n", kind, nodename)
|
fmt.Printf("-> %q name=%q\n", kind, nodename)
|
||||||
if classInner, ok := node["inner"].([]interface{}); ok {
|
if classInner, ok := node["inner"].([]interface{}); ok {
|
||||||
obj, err := processType(classInner, nodename)
|
|
||||||
|
// Check if this was 'struct' (default visible) or 'class' (default invisible)
|
||||||
|
visible := true
|
||||||
|
if tagUsed, ok := node["tagUsed"].(string); ok && tagUsed == "class" {
|
||||||
|
visible = false
|
||||||
|
}
|
||||||
|
|
||||||
|
// Process the inner class definition
|
||||||
|
obj, err := processType(classInner, nodename, visible)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
@ -63,7 +71,7 @@ func parseHeader(inner []interface{}) (*parsedHeader, error) {
|
|||||||
return &ret, nil // done
|
return &ret, nil // done
|
||||||
}
|
}
|
||||||
|
|
||||||
func processType(inner []interface{}, className string) (nativeClass, error) {
|
func processType(inner []interface{}, className string, visibility bool) (nativeClass, error) {
|
||||||
var ret nativeClass
|
var ret nativeClass
|
||||||
ret.className = className
|
ret.className = className
|
||||||
|
|
||||||
@ -80,7 +88,27 @@ nextMethod:
|
|||||||
}
|
}
|
||||||
|
|
||||||
switch kind {
|
switch kind {
|
||||||
|
case "AccessSpecDecl":
|
||||||
|
// Swap between visible/invisible
|
||||||
|
access, ok := node["access"].(string)
|
||||||
|
if !ok {
|
||||||
|
panic("AccessSpecDecl missing `access` field")
|
||||||
|
}
|
||||||
|
|
||||||
|
switch access {
|
||||||
|
case "public":
|
||||||
|
visibility = true
|
||||||
|
case "private", "protected":
|
||||||
|
visibility = false
|
||||||
|
default:
|
||||||
|
panic("unexpected access visibility '" + access + "'")
|
||||||
|
}
|
||||||
|
|
||||||
case "CXXMethodDecl":
|
case "CXXMethodDecl":
|
||||||
|
if !visibility {
|
||||||
|
continue // Skip private/protected
|
||||||
|
}
|
||||||
|
|
||||||
// Method
|
// Method
|
||||||
methodName, ok := node["name"].(string)
|
methodName, ok := node["name"].(string)
|
||||||
if !ok {
|
if !ok {
|
||||||
|
Loading…
Reference in New Issue
Block a user