--- nfo/perl/libs/Data/Storage/Handler/Tangram.pm 2003/12/14 01:48:36 1.45 +++ nfo/perl/libs/Data/Storage/Handler/Tangram.pm 2004/05/06 12:54:34 1.46 @@ -1,8 +1,11 @@ ############################################ # -# $Id: Tangram.pm,v 1.45 2003/12/14 01:48:36 jonen Exp $ +# $Id: Tangram.pm,v 1.46 2004/05/06 12:54:34 jonen Exp $ # # $Log: Tangram.pm,v $ +# Revision 1.46 2004/05/06 12:54:34 jonen +# + bugfix related to multiple select-'filter' +# # Revision 1.45 2003/12/14 01:48:36 jonen # small HACK at _insertChildNode: some special Childnodes should not be created because existing objects have to be selected! # TODO: make this more generic, e.g. implement a special flag at Schema @@ -529,7 +532,7 @@ my @results; $logger->debug( __PACKAGE__ . "->getListFiltered( nodename => '" . $in->{nodename} . "' )" ); - #print Dumper($filters); + #print "Filter_payload: " . Dumper($in->{filters}) . "\n"; # 1. "Remote Object Handle" - get set of objects from odbms by object name my $remote = $self->{_COREHANDLE}->remote($in->{nodename}); @@ -585,7 +588,7 @@ $orm_filter_tmp = $left->$op($right); } - if (not $orm_filter) { + if (!ref($orm_filter)) { $orm_filter = $orm_filter_tmp; } else { $orm_filter = $orm_filter->and($orm_filter_tmp); @@ -594,6 +597,9 @@ } $orm_query->{filter} = $orm_filter; + + # debug point: + #print "Filter: " . Dumper($orm_query->{filter}) . "\n"; # was: @@ -835,6 +841,7 @@ my $object = $cursor->getNextEntry(); $self->erase($object); + $self->unload($object); } elsif ($crud eq 'CREATE') {