2 # ============================================================================
3 # Zebra perl API header
4 # =============================================================================
7 # ============================================================================
8 package IDZebra::Resultset;
10 use IDZebra::Logger qw(:flags :calls);
11 use IDZebra::Repository;
12 use Scalar::Util qw(weaken);
14 our @ISA = qw(IDZebra::Logger);
17 # -----------------------------------------------------------------------------
18 # Class constructors, destructor
19 # -----------------------------------------------------------------------------
21 my ($proto,$session, %args) = @_;
22 my $class = ref($proto) || $proto;
24 $self->{session} = $session;
25 weaken ($self->{session});
28 $self->{ro} = IDZebra::RetrievalObj->new();
29 $self->{odr_stream} = IDZebra::odr_createmem($IDZebra::ODR_DECODE);
31 $self->{name} = $args{name};
32 $self->{recordCount} = $args{recordCount};
33 $self->{errCode} = $args{errCode};
34 $self->{errString} = $args{errString};
36 bless ($self, $class);
38 # $self->{session}{resultsets}{$args{name}} = $self;
39 # weaken ($self->{session}{resultsets}{$args{name}};
46 return ($self->{recordCount});
51 return ($self->{errCode});
56 return ($self->{errCode});
59 # =============================================================================
65 if ($self->{odr_stream}) {
66 IDZebra::odr_reset($self->{odr_stream});
67 IDZebra::odr_destroy($self->{odr_stream});
68 $self->{odr_stream} = undef;
72 # delete($self->{session}{resultsets}{$self->{name}});
73 delete($self->{session});
75 # -----------------------------------------------------------------------------
77 my ($self, %args) = @_;
79 my $from = $args{from} ? $args{from} : 1;
80 my $to = $args{to} ? $args{to} : $self->{recordCount};
82 my $elementSet = $args{elementSet} ? $args{elementSet} : 'R';
83 my $schema = $args{schema} ? $args{schema} : '';
84 my $recordSyntax = $args{recordSyntax} ? $args{recordSyntax} : '';
86 my $class = $args{class} ? $args{class} : '';
89 my $ro = IDZebra::RetrievalObj->new();
90 IDZebra::records_retrieve($self->{session}{zh},
103 for (my $i=$from; $i<=$to; $i++) {
104 my $rec = IDZebra::RetrievalRecord->new();
105 IDZebra::record_retrieve($ro, $self->{odr_stream}, $rec, $i-$from+1);
113 IDZebra::odr_reset($self->{odr_stream});
118 # ============================================================================
120 my ($self, $sortspec, $setname) = @_;
122 $_[0] = $self->{session}->sortResultsets($sortspec,
123 $self->{name}, ($self));
126 return ($self->{session}->sortResultsets($sortspec,
131 # ============================================================================
136 IDZebra::Resultset - Representation of Zebra search results
142 The I<Resultset> object represents results of a Zebra search. Contains number of hits, search status, and can be used to sort and retrieve the records.
148 printf ("RS Status is %d (%s)\n", $rs->errCode, $rs->errString);
150 I<$rs-E<gt>errCode> is 0, if there were no errors during search.
152 =head1 RETRIEVING RECORDS
161 Peter Popovics, pop@technomat.hu
165 IDZebra, IDZebra::Data1, Zebra documentation