Mercurial > pidgin
view libpurple/plugins/tcl/signal-test.tcl @ 22403:dfe4a3e3336a
serv_got_joined_chat() emits "chat-joined" but it also calls
purple_conversation_new() which emits "conversation-created", so attaching
to both signals would make create_conv and attach_signals to be called twice,
leaking the list of signal ids:
==30871== 67 (43 direct, 24 indirect) bytes in 3 blocks are definitely lost in loss record 94 of 265
==30871== at 0x4006A6E: malloc (vg_replace_malloc.c:207)
==30871== by 0xA1CAF5: g_malloc (in /lib/libglib-2.0.so.0.1400.6)
==30871== by 0xA31B3A: g_slice_alloc (in /lib/libglib-2.0.so.0.1400.6)
==30871== by 0xA32D9A: g_slist_append (in /lib/libglib-2.0.so.0.1400.6)
==30871== by 0x4F1CA4A: attach_signals (notify.c:321)
==30871== by 0x4F1CDCA: conv_created (notify.c:388)
Credit goes to Andrew Gaul for sending me this valgrind trace, blame me if
this breaks anything.
author | Ka-Hing Cheung <khc@hxbc.us> |
---|---|
date | Mon, 03 Mar 2008 07:03:54 +0000 |
parents | f4c72a722741 |
children |
line wrap: on
line source
purple::signal connect [purple::account handle] account-away { account state message } { purple::debug -info "tcl signal" "account-away [purple::account username $account] \"$state\" \"$message\"" } purple::signal connect [purple::account handle] account-connecting { account } { purple::debug -info "tcl signal" "account-connecting [purple::account username $account]" } purple::signal connect [purple::account handle] account-set-info { account info } { purple::debug -info "tcl signal" "account-set-info [purple::account username $account] $info" } purple::signal connect [purple::account handle] account-setting-info { account info } { purple::debug -info "tcl signal" "account-set-info [purple::account username $account] $info" } purple::signal connect [purple::buddy handle] buddy-away { buddy } { purple::debug -info "tcl signal" "buddy-away [purple::account username [lindex $buddy 2]] [lindex $buddy 1]" } purple::signal connect [purple::buddy handle] buddy-back { buddy } { purple::debug -info "tcl signal" "buddy-back [purple::account username [lindex $buddy 2]] [lindex $buddy 1]" } purple::signal connect [purple::buddy handle] buddy-idle { buddy } { purple::debug -info "tcl signal" "buddy-idle [purple::account username [lindex $buddy 2]] [lindex $buddy 1]" } purple::signal connect [purple::buddy handle] buddy-unidle { buddy } { purple::debug -info "tcl signal" "buddy-unidle [purple::account username [lindex $buddy 2]] [lindex $buddy 1]" } purple::signal connect [purple::buddy handle] buddy-signed-on { buddy } { purple::debug -info "tcl signal" "buddy-signed-on [purple::account username [lindex $buddy 2]] [lindex $buddy 1]" } purple::signal connect [purple::buddy handle] buddy-signed-off { buddy } { purple::debug -info "tcl signal" "buddy-signed-off [purple::account username [lindex $buddy 2]] [lindex $buddy 1]" } purple::signal connect [purple::core handle] quitting {} { purple::debug -info "tcl signal" "quitting" } purple::signal connect [purple::conversation handle] receiving-chat-msg { account who what id flags } { purple::debug -info "tcl signal" "receiving-chat-msg [purple::account username $account] $id $flags $who \"$what\"" return 0 } purple::signal connect [purple::conversation handle] receiving-im-msg { account who what id flags } { purple::debug -info "tcl signal" "receiving-im-msg [purple::account username $account] $id $flags $who \"$what\"" return 0 } purple::signal connect [purple::conversation handle] received-chat-msg { account who what id flags } { purple::debug -info "tcl signal" "received-chat-msg [purple::account username $account] $id $flags $who \"$what\"" } purple::signal connect [purple::conversation handle] received-im-msg { account who what id flags } { purple::debug -info "tcl signal" "received-im-msg [purple::account username $account] $id $flags $who \"$what\"" } purple::signal connect [purple::conversation handle] sending-chat-msg { account what id } { purple::debug -info "tcl signal" "sending-chat-msg [purple::account username $account] $id \"$what\"" return 0 } purple::signal connect [purple::conversation handle] sending-im-msg { account who what } { purple::debug -info "tcl signal" "sending-im-msg [purple::account username $account] $who \"$what\"" return 0 } purple::signal connect [purple::conversation handle] sent-chat-msg { account id what } { purple::debug -info "tcl signal" "sent-chat-msg [purple::account username $account] $id \"$what\"" } purple::signal connect [purple::conversation handle] sent-im-msg { account who what } { purple::debug -info "tcl signal" "sent-im-msg [purple::account username $account] $who \"$what\"" } purple::signal connect [purple::connection handle] signed-on { gc } { purple::debug -info "tcl signal" "signed-on [purple::account username [purple::connection account $gc]]" } purple::signal connect [purple::connection handle] signed-off { gc } { purple::debug -info "tcl signal" "signed-off [purple::account username [purple::connection account $gc]]" } purple::signal connect [purple::connection handle] signing-on { gc } { purple::debug -info "tcl signal" "signing-on [purple::account username [purple::connection account $gc]]" } if { 0 } { purple::signal connect signing-off { purple::debug -info "tcl signal" "signing-off [purple::account username [purple::connection account $event::gc]]" } purple::signal connect update-idle { purple::debug -info "tcl signal" "update-idle" } } purple::signal connect [purple::plugins handle] plugin-load args { purple::debug -info "tcl signal" "plugin-load [list $args]" } purple::signal connect [purple::plugins handle] plugin-unload args { purple::debug -info "tcl signal" "plugin-unload [list $args]" } purple::signal connect [purple::savedstatuses handle] savedstatus-changed args { purple::debug -info "tcl signal" "savedstatus-changed [list $args]" purple::debug -info "tcl signal" "purple::savedstatus current = [purple::savedstatus current]" } proc plugin_init { } { list "Tcl Signal Test" \ "$purple::version" \ "Tests Tcl signal handlers" \ "Debugs a ridiculous amount of signal information." \ "Ethan Blanton <elb@pidgin.im>" \ "http://www.pidgin.im/" }