2024-08-27 18:44:10 +12:00
|
|
|
package main
|
|
|
|
|
2024-11-15 14:23:30 +13:00
|
|
|
func blocklist_MethodAllowed(m *CppMethod) bool {
|
|
|
|
if err := AllowType(m.ReturnType, true); err != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, p := range m.Parameters {
|
|
|
|
if err := AllowType(p, false); err != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Nothing was blocked
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
2024-08-27 18:44:10 +12:00
|
|
|
// astTransformBlocklist filters out methods using too-complex parameter types,
|
|
|
|
// and entire classes that may be disallowed.
|
|
|
|
func astTransformBlocklist(parsed *CppParsedHeader) {
|
|
|
|
|
2024-10-26 12:08:36 +13:00
|
|
|
// Whole-classes
|
|
|
|
|
|
|
|
j := 0
|
|
|
|
for _, c := range parsed.Classes {
|
|
|
|
if !AllowClass(c.ClassName) {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
// 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
|
|
|
|
|
2024-08-27 18:44:10 +12:00
|
|
|
for i, c := range parsed.Classes {
|
|
|
|
|
|
|
|
// Constructors
|
|
|
|
|
|
|
|
j := 0
|
|
|
|
nextCtor:
|
|
|
|
for _, m := range c.Ctors {
|
2024-11-15 14:23:30 +13:00
|
|
|
if !blocklist_MethodAllowed(&m) {
|
2024-08-27 18:44:10 +12:00
|
|
|
continue nextCtor
|
|
|
|
}
|
|
|
|
|
|
|
|
// Keep
|
|
|
|
c.Ctors[j] = m
|
|
|
|
j++
|
|
|
|
}
|
|
|
|
c.Ctors = c.Ctors[:j] // reslice
|
|
|
|
|
|
|
|
// Methods
|
|
|
|
|
|
|
|
j = 0
|
|
|
|
nextMethod:
|
|
|
|
for _, m := range c.Methods {
|
2024-11-15 14:23:30 +13:00
|
|
|
if !blocklist_MethodAllowed(&m) {
|
2024-08-27 18:44:10 +12:00
|
|
|
continue nextMethod
|
|
|
|
}
|
|
|
|
|
|
|
|
// Keep
|
|
|
|
c.Methods[j] = m
|
|
|
|
j++
|
|
|
|
}
|
|
|
|
c.Methods = c.Methods[:j] // reslice
|
|
|
|
|
|
|
|
parsed.Classes[i] = c
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|