I think I got it now. It looks like
a libsoup vapi bug.

After looking at the generated C more carefully,
I find that closure doesn't work with queue_message
at all!

The closure is created like this:

    _data1_ = g_slice_new0 (Block1Data);
    _data1_->_ref_count_ = 1;

the call to queue_message is compiled to this:

    soup_session_queue_message ((SoupSession*) session, _tmp22_,
___lambda2__soup_session_callback, _data1_);

   /* Note: there is NO g_object_ref(_data1_) before the call,
      and soup_session_queue_message simply treat
      _data1_ as typeless blob.

      Hence, refcount is still 1 */

at the end of the scope, the entire closure
is destroyed like this:

    block1_data_unref (_data1_);  // recursively unref everything
    _data1_ = NULL;

Hence, by the time the lambda executes, the closure has
already gone.


Nice day
Nor Jaidi Tuah





PRIVILEGED/CONFIDENTIAL information may be contained in this message. If you 
are neither the addressee (intended recipient) nor an authorised recipient of 
the addressee, and have received this message in error, please destroy this 
message (including attachments) and notify the sender immediately. STRICT 
PROHIBITION: This message, whether in part or in whole, should not be reviewed, 
retained, copied, reused, disclosed, distributed or used for any purpose 
whatsoever. Such unauthorised use may be unlawful and may contain material 
protected by the Official Secrets Act (Cap 153) of the Laws of Brunei 
Darussalam. DISCLAIMER: We/This Department/The Government of Brunei Darussalam, 
accept[s] no responsibility for loss or damage arising from the use of this 
message in any manner whatsoever. Our messages are checked for viruses but we 
do not accept liability for any viruses which may be transmitted in or with 
this message.
_______________________________________________
vala-list mailing list
[email protected]
https://mail.gnome.org/mailman/listinfo/vala-list

Reply via email to