miqt/cmd/genbindings/transformblocklist.go

86 lines
1.6 KiB
Go
Raw Normal View History

package main
import "log"
func blocklist_MethodAllowed(m *CppMethod) error {
if err := AllowType(m.ReturnType, true); err != nil {
return err
}
for _, p := range m.Parameters {
if err := AllowType(p, false); err != nil {
return err
}
}
// Nothing was blocked
return nil
}
// astTransformBlocklist filters out methods using too-complex parameter types,
// and entire classes that may be disallowed.
func astTransformBlocklist(parsed *CppParsedHeader) {
// Whole-classes
j := 0
for _, c := range parsed.Classes {
if !AllowClass(c.ClassName) {
continue
}
// If this class is abstract, but we return !AllowVirtualForClass, then
// delete its constructors
if c.Abstract && !AllowVirtualForClass(c.ClassName) {
c.Ctors = nil
}
// Keep
parsed.Classes[j] = c
j++
}
parsed.Classes = parsed.Classes[:j] // reslice
// For the kept classes, filter ctors and methods within the class, based
// on the parameter types and return types
for i, c := range parsed.Classes {
// Constructors
j := 0
nextCtor:
for _, m := range c.Ctors {
if err := blocklist_MethodAllowed(&m); err != nil {
log.Printf("Blocking constructor %q(%v): %s", m.MethodName, m.Parameters, err)
continue nextCtor
}
// Keep
c.Ctors[j] = m
j++
}
c.Ctors = c.Ctors[:j] // reslice
// Methods
j = 0
nextMethod:
for _, m := range c.Methods {
if err := blocklist_MethodAllowed(&m); err != nil {
log.Printf("Blocking method %q(%v): %s", m.MethodName, m.Parameters, err)
continue nextMethod
}
// Keep
c.Methods[j] = m
j++
}
c.Methods = c.Methods[:j] // reslice
parsed.Classes[i] = c
}
}