From 2fa853d836a16479acde7c983aa302bd92639cb2 Mon Sep 17 00:00:00 2001 From: mappu Date: Sat, 26 Oct 2024 11:56:56 +1300 Subject: [PATCH] genbindings/config: make AllowType a superset of AllowClass --- cmd/genbindings/config-allowlist.go | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/cmd/genbindings/config-allowlist.go b/cmd/genbindings/config-allowlist.go index a9bca9d3..63ca529a 100644 --- a/cmd/genbindings/config-allowlist.go +++ b/cmd/genbindings/config-allowlist.go @@ -198,6 +198,9 @@ func AllowMethod(className string, mm CppMethod) error { return nil // OK, allow } +// AllowType controls whether to permit binding of a method, if a method uses +// this type in its parameter list or return type. +// Any type not permitted by AllowClass is also not permitted by this method. func AllowType(p CppParameter, isReturnType bool) error { if p.QMapOf() { @@ -222,6 +225,9 @@ func AllowType(p CppParameter, isReturnType bool) error { return ErrTooComplex } } + if !AllowClass(p.ParameterType) { + return ErrTooComplex // This whole class type has been blocked, not only as a parameter/return type + } if strings.Contains(p.ParameterType, "(*)") { // Function pointer. return ErrTooComplex // e.g. QAccessible_InstallFactory @@ -356,9 +362,6 @@ func AllowType(p CppParameter, isReturnType bool) error { "QtMsgType", // e.g. qdebug.h TODO Defined in qlogging.h, but omitted because it's predefined in qglobal.h, and our clangexec is too agressive "QTextStreamFunction", // e.g. qdebug.h "QFactoryInterface", // qfactoryinterface.h - "QItemSelection", // used by qabstractproxymodel.h, also blocked in AllowClass above, class extends a List - "QTextStreamManipulator", // used by qdebug.h, also blocked in AllowClass above - "QException", // used by qfutureinterface.h, also blocked in AllowClass above "QTextEngine", // used by qtextlayout.h, also blocked in ImportHeaderForClass above "QVulkanInstance", // e.g. qwindow.h. Not tackling vulkan yet "QPlatformNativeInterface", // e.g. QGuiApplication::platformNativeInterface(). Private type, could probably expose as uintptr. n.b. Changes in Qt6