aboutsummaryrefslogtreecommitdiff
path: root/examples
diff options
context:
space:
mode:
authormescalinum <mescalinum@users.sourceforge.net>2011-11-28 23:59:13 +0000
committermescalinum <mescalinum@users.sourceforge.net>2011-11-28 23:59:13 +0000
commitef18d8daab4aad16f833fe17fe8be97671eebe71 (patch)
tree96cab517ef9f0be374e506341aaff8eddc38b902 /examples
parentd08fb1df93b9f9585f401b1cf156df627c1cf024 (diff)
Fix pd_bind crash in [bitmap] (bug #3429577).
This commit causes [bitmap] to break further, because there are now two string representations of a t_pd*: 1. the one provided by SWIG, unaccessible by tclpd; 2. the tclpd synthetic one In order to be fixed, hashtable must become a bidirectional hashmap, so that a reverse lookup in the object_table is possible (needed in order to make a %typemap(out) t_pd *). svn path=/trunk/externals/loaders/tclpd/; revision=15801
Diffstat (limited to 'examples')
-rw-r--r--examples/bitmap.tcl18
1 files changed, 13 insertions, 5 deletions
diff --git a/examples/bitmap.tcl b/examples/bitmap.tcl
index e1d0495..c54d51f 100644
--- a/examples/bitmap.tcl
+++ b/examples/bitmap.tcl
@@ -60,13 +60,20 @@ proc+ bitmap::constructor {self args} {
0_config $self {*}$args
set @rcvLoadData {#bitmap}
+
+ set x [pd_findbyclass $@rcvLoadData bitmap]
+ if {$x ne "NULL"} {
+ # prevent crash due to stale bound receivers:
+ pd_unbind $x $@rcvLoadData
+ }
+
pd_bind $self $@rcvLoadData
}
proc+ bitmap::destructor {self} {
- if {$@rcvLoadData ne {}} {
- #should not happen!
- pd_unbind $self $@rcvLoadData
+ set x [pd_findbyclass $@rcvLoadData bitmap]
+ if {$x ne "NULL"} {
+ pd_unbind $x $@rcvLoadData
}
if {[dict get $@config -receivesymbol] ne {}} {
pd_unbind $self $@recv
@@ -248,9 +255,10 @@ proc+ bitmap::0_setdata {self args} {
}
set @data [list]
foreach i $d {lappend @data [expr {int($i)}]}
- if {$@rcvLoadData ne {}} {
+
+ set x [pd_findbyclass $@rcvLoadData bitmap]
+ if {$x ne "NULL"} {
pd_unbind $self $@rcvLoadData
- set @rcvLoadData {}
}
}