Changeset: ac002b82f1da for MonetDB URL: http://dev.monetdb.org/hg/MonetDB?cmd=changeset;node=ac002b82f1da Modified Files: MonetDB5/src/modules/kernel/batcalc.mx Branch: Jun2010 Log Message:
merge with Feb2010: more reference counting fixes diffs (69 lines): diff -r 213d33113b88 -r ac002b82f1da MonetDB5/src/modules/kernel/batcalc.mx --- a/MonetDB5/src/modules/kernel/batcalc.mx Sat Jun 19 21:09:04 2010 +0200 +++ b/MonetDB5/src/modules/kernel/batcalc.mx Sun Jun 20 11:47:59 2010 +0200 @@ -734,8 +734,10 @@ } BBPkeepref(*ret = bn->batCacheid); - BBPreleaseref(b->batCacheid); - BBPreleaseref(right->batCacheid); + if (b != bn) + BBPreleaseref(b->batCacheid); + if (right != bn) + BBPreleaseref(right->batCacheid); return res; } @@ -788,7 +790,8 @@ bn = r; } BBPkeepref(*ret = bn->batCacheid); - BBPreleaseref(b->batCacheid); + if (b != bn) + BBPreleaseref(b->batCacheid); return res; } @@ -837,7 +840,8 @@ bn = r; } BBPkeepref(*ret = bn->batCacheid); - BBPreleaseref(b->batCacheid); + if (b != bn) + BBPreleaseref(b->batCacheid); return res; } @- @@ -1017,8 +1021,10 @@ msg = batac...@2_@3...@4_@5(bn,b,right); BBPkeepref(*ret = bn->batCacheid); - BBPreleaseref(b->batCacheid); - BBPreleaseref(right->batCacheid); + if (b != bn) + BBPreleaseref(b->batCacheid); + if (right != bn) + BBPreleaseref(right->batCacheid); return msg; } @@ -1070,7 +1076,8 @@ if (!(bn->batDirty&2)) bn = BATsetaccess(bn, BAT_READ); BBPkeepref(*ret = bn->batCacheid); - BBPreleaseref(b->batCacheid); + if (b != bn) + BBPreleaseref(b->batCacheid); return MAL_SUCCEED; } @@ -1122,7 +1129,8 @@ if (!(bn->batDirty&2)) bn = BATsetaccess(bn, BAT_READ); BBPkeepref(*ret = bn->batCacheid); - BBPreleaseref(b->batCacheid); + if (b != bn) + BBPreleaseref(b->batCacheid); return MAL_SUCCEED; } @c _______________________________________________ Checkin-list mailing list Checkin-list@monetdb.org http://mail.monetdb.org/mailman/listinfo/checkin-list