gobject: Clarify behaviour of adding weak refs during disposal

The previous wording was not clear about what happens if a new weak ref
is taken during disposal (shortly after resurrecting the object with a
new strong ref, otherwise taking the weak ref is invalid).

See: https://gitlab.gnome.org/GNOME/glib/-/merge_requests/2064/diffs#note_1270092

Signed-off-by: Philip Withnall <pwithnall@endlessos.org>

Helps: #2390
This commit is contained in:
Philip Withnall 2021-09-20 13:18:03 +01:00
parent 97716e7b01
commit 3b67d53227

View File

@ -4552,11 +4552,14 @@ g_initially_unowned_class_init (GInitiallyUnownedClass *klass)
* objects. * objects.
* *
* If the object's #GObjectClass.dispose method results in additional * If the object's #GObjectClass.dispose method results in additional
* references to the object being held, any #GWeakRefs taken * references to the object being held (re-referencing), any #GWeakRefs taken
* before it was disposed will continue to point to %NULL. If * before it was disposed will continue to point to %NULL. Any #GWeakRefs taken
* #GWeakRefs are taken after the object is disposed and * during disposal and after re-referencing, or after disposal has returned due
* re-referenced, they will continue to point to it until its refcount * to the re-referencing, will continue to point to the object until its refcount
* goes back to zero, at which point they too will be invalidated. * goes back to zero, at which point they too will be invalidated.
*
* It is invalid to take a #GWeakRef on an object during #GObjectClass.dispose
* without first having or creating a strong reference to the object.
*/ */
/** /**