Patch-Source: https://github.com/gtkd-developers/gir-to-d/commit/f4dfc8cfb130280291db458629ab11b6904e5191 From f4dfc8cfb130280291db458629ab11b6904e5191 Mon Sep 17 00:00:00 2001 From: Mike Wey Date: Wed, 23 Mar 2022 23:26:51 +0100 Subject: [PATCH] Fix segfault with the latest Glib. --- source/gtd/GirFunction.d | 27 ++++++++------------------- 1 file changed, 8 insertions(+), 19 deletions(-) diff --git a/source/gtd/GirFunction.d b/source/gtd/GirFunction.d index 49a663d..6a8c15b 100644 --- a/source/gtd/GirFunction.d +++ b/source/gtd/GirFunction.d @@ -398,7 +398,7 @@ final class GirFunction if ( returnType.length > -1 && param == params[returnType.length] && params[returnType.length].direction != GirParamDirection.Default ) continue; - if ( paramCount == 0 && strct.type == GirStructType.Record && isInstanceParam(param) ) + if ( paramCount == 0 && strct.type == GirStructType.Record && isInstanceParam(param) && type != GirFunctionType.Constructor ) continue; if ( paramCount++ > 0 ) @@ -444,26 +444,15 @@ final class GirFunction if ( instanceParam || ( !params.empty && isInstanceParam(params[0])) ) { - GirStruct dType; - - if ( instanceParam ) - { - dType = strct.pack.getStruct(instanceParam.type.name); - - if ( dType.cType != instanceParam.type.cType.removePtr() && !instanceParam.type.cType.among("gpointer", "gconstpointer") ) - gtkCall ~= "cast("~ stringToGtkD(instanceParam.type.cType, wrapper.aliasses, localAliases()) ~")"; - } - else - { - dType = strct.pack.getStruct(params[0].type.name); + GirParam instance = instanceParam ? instanceParam : params[0]; + GirStruct dType = strct.pack.getStruct(instance.type.name); - if ( dType.cType != params[0].type.cType.removePtr() && !params[0].type.cType.among("gpointer", "gconstpointer") ) - gtkCall ~= "cast("~ stringToGtkD(params[0].type.cType, wrapper.aliasses, localAliases()) ~")"; - } + if ( dType.cType != instance.type.cType.removePtr() && !instance.type.cType.among("gpointer", "gconstpointer") ) + gtkCall ~= "cast("~ stringToGtkD(instance.type.cType, wrapper.aliasses, localAliases()) ~")"; - if ( instanceParam && instanceParam.type.name in strct.structWrap ) + if ( instance && instance.type.name in strct.structWrap ) { - GirStruct insType = strct.pack.getStruct(strct.structWrap[instanceParam.type.name]); + GirStruct insType = strct.pack.getStruct(strct.structWrap[instance.type.name]); if ( insType ) dType = insType; @@ -471,7 +460,7 @@ final class GirFunction if ( type == GirFunctionType.Constructor || strct.isNamespace() || strct.noNamespace ) { - string id = tokenToGtkD(instanceParam.name, wrapper.aliasses, localAliases()); + string id = tokenToGtkD(instance.name, wrapper.aliasses, localAliases()); if ( dType && !(dType.isNamespace() || dType.noNamespace) ) gtkCall ~= "("~ id ~" is null) ? null : "~ id ~"."~ dType.getHandleFunc() ~"()";