girepository/parser: Clarify ownership of nodetype nodes

We may had free'd a list of items without freeing the items in there.
So now, properly steal the data instead and free everything.
This commit is contained in:
Marco Trevisan (Treviño) 2024-05-24 17:01:25 +02:00
parent bfb62e9095
commit 7c9a604eb2

View File

@ -2248,7 +2248,7 @@ end_type_top (ParseContext *ctx)
if (!ctx->type_parameters) if (!ctx->type_parameters)
goto out; goto out;
typenode = (GIIrNodeType*)ctx->type_parameters->data; typenode = (GIIrNodeType*) g_steal_pointer (&ctx->type_parameters->data);
/* Default to pointer for unspecified containers */ /* Default to pointer for unspecified containers */
if (typenode->tag == GI_TYPE_TAG_ARRAY || if (typenode->tag == GI_TYPE_TAG_ARRAY ||
@ -2297,7 +2297,7 @@ end_type_top (ParseContext *ctx)
g_printerr("current node is %d\n", CURRENT_NODE (ctx)->type); g_printerr("current node is %d\n", CURRENT_NODE (ctx)->type);
g_assert_not_reached (); g_assert_not_reached ();
} }
g_list_free (ctx->type_parameters); g_list_free_full (ctx->type_parameters, (GDestroyNotify) gi_ir_node_free);
out: out:
ctx->type_depth = 0; ctx->type_depth = 0;
@ -2313,7 +2313,7 @@ end_type_recurse (ParseContext *ctx)
parent = (GIIrNodeType *) ((GList*)ctx->type_stack->data)->data; parent = (GIIrNodeType *) ((GList*)ctx->type_stack->data)->data;
if (ctx->type_parameters) if (ctx->type_parameters)
param = (GIIrNodeType *) ctx->type_parameters->data; param = (GIIrNodeType *) g_steal_pointer (&ctx->type_parameters->data);
if (parent->tag == GI_TYPE_TAG_ARRAY || if (parent->tag == GI_TYPE_TAG_ARRAY ||
parent->tag == GI_TYPE_TAG_GLIST || parent->tag == GI_TYPE_TAG_GLIST ||
@ -2322,7 +2322,7 @@ end_type_recurse (ParseContext *ctx)
g_assert (param != NULL); g_assert (param != NULL);
if (parent->parameter_type1 == NULL) if (parent->parameter_type1 == NULL)
parent->parameter_type1 = param; parent->parameter_type1 = g_steal_pointer (&param);
else else
g_assert_not_reached (); g_assert_not_reached ();
} }
@ -2331,13 +2331,14 @@ end_type_recurse (ParseContext *ctx)
g_assert (param != NULL); g_assert (param != NULL);
if (parent->parameter_type1 == NULL) if (parent->parameter_type1 == NULL)
parent->parameter_type1 = param; parent->parameter_type1 = g_steal_pointer (&param);
else if (parent->parameter_type2 == NULL) else if (parent->parameter_type2 == NULL)
parent->parameter_type2 = param; parent->parameter_type2 = g_steal_pointer (&param);
else else
g_assert_not_reached (); g_assert_not_reached ();
} }
g_list_free (ctx->type_parameters); g_clear_pointer ((GIIrNode **) &param, gi_ir_node_free);
g_list_free_full (ctx->type_parameters, (GDestroyNotify) gi_ir_node_free);
ctx->type_parameters = (GList *)ctx->type_stack->data; ctx->type_parameters = (GList *)ctx->type_stack->data;
ctx->type_stack = g_list_delete_link (ctx->type_stack, ctx->type_stack); ctx->type_stack = g_list_delete_link (ctx->type_stack, ctx->type_stack);
} }