Skip to content

ghash: comment g_hash_table_steal_extended() about not destroying key/value

Thomas Haller requested to merge th/hash-steal-doc into main

The previous text was technically correct, but not very clear what happens with the ownership of the key/value if it was not returned. Elaborate on the fact, that the key/value is never destroyed, even if not requested by the user.

I intuitively expected the function to behave differently, that is, to destroy the key/value if (and only if) it was not returned. That is, when the function does not return a pointer, then it would destroy it. That would seem more consistent to me, where ownership is either transferred to the caller, or the resource destroyed during the steal.

On the other hand, the existing behaviors is:

  • is consistent with g_hash_table_steal() and never destroys key/value.
  • behaves the same, regardless whether the key/value was returned.

So the existing behavior may be better.

Just elaborate on that detail in the doc.

Merge request reports