[Koha-cvs] CVS: koha/C4 AuthoritiesMarc.pm,1.12,1.13
Henri-Damien LAURENT
hdl at users.sourceforge.net
Tue Apr 5 17:24:00 CEST 2005
Update of /cvsroot/koha/koha/C4
In directory sc8-pr-cvs1.sourceforge.net:/tmp/cvs-serv32069/C4
Modified Files:
AuthoritiesMarc.pm
Log Message:
Searching for double entries when adding a new authority.
Index: AuthoritiesMarc.pm
===================================================================
RCS file: /cvsroot/koha/koha/C4/AuthoritiesMarc.pm,v
retrieving revision 1.12
retrieving revision 1.13
diff -C2 -r1.12 -r1.13
*** AuthoritiesMarc.pm 5 Apr 2005 09:58:48 -0000 1.12
--- AuthoritiesMarc.pm 5 Apr 2005 15:23:41 -0000 1.13
***************
*** 76,82 ****
# "Normal" statements
# quote marc fields/subfields
! for (my $i=0;$i<$#{$tags};$i++) {
if (@$tags[$i]) {
@$tags[$i] = $dbh->quote(@$tags[$i]);
}
}
--- 76,84 ----
# "Normal" statements
# quote marc fields/subfields
! for (my $i=0;$i<=$#{$tags};$i++) {
! # warn " $i: ".@$tags[$i];
if (@$tags[$i]) {
@$tags[$i] = $dbh->quote(@$tags[$i]);
+ # warn " $i After process: ".@$tags[$i];
}
}
***************
*** 197,200 ****
--- 199,203 ----
if (@$value[$i]) {
$nb_active++;
+ # warn " @$tags[$i]";
if ($nb_active==1) {
if (@$operator[$i] eq "start") {
***************
*** 850,877 ****
my $dbh = C4::Context->dbh;
! warn "".$record->as_formatted;
# search duplicate on ISBN, easy and fast...
! my $sth = $dbh->prepare("select auth_tag_to_report from auth_types where authtypecode=?");
$sth->execute($authtypecode);
! my ($auth_tag_to_report) = $sth->fetchrow;
$sth->finish;
# a more complex search : build a request for authoritysearch
my (@tags, @and_or, @excluding, @operator, @value, $offset, $length);
# search on biblio.title
! warn " tag a reporter : $auth_tag_to_report";
if ($record->fields($auth_tag_to_report)) {
! my $sth = $dbh->prepare("select tagfield,tagsubfield from auth_subfield_structure where tagfield=? and authtypecode=? and tab >= 0");
! $sth->execute($auth_tag_to_report,$authtypecode);
! warn " Champ $auth_tag_to_report present";
! while (my ($tag,$subfield) = $sth->fetchrow){
! if ($record->field($tag)->subfields($subfield)) {
! warn "tag :".$tag." subfield: $subfield value : $record->field($tag)->subfield($subfield)->as_formatted";
! push @tags, "'".$tag.$subfield."'";
push @and_or, "and";
push @excluding, "";
push @operator, "contains";
! push @value, $record->field($tag)->subfield($subfield);
}
}
}
--- 853,902 ----
my $dbh = C4::Context->dbh;
! # warn "".$record->as_formatted;
# search duplicate on ISBN, easy and fast...
! my $sth = $dbh->prepare("select auth_tag_to_report,summary from auth_types where authtypecode=?");
$sth->execute($authtypecode);
! my ($auth_tag_to_report,$taglist) = $sth->fetchrow;
$sth->finish;
# a more complex search : build a request for authoritysearch
my (@tags, @and_or, @excluding, @operator, @value, $offset, $length);
# search on biblio.title
! # warn " tag a reporter : $auth_tag_to_report";
! warn "taglist ".$taglist;
! my @subfield = split /\[/, $taglist;
! my $max = @subfield;
! for (my $i=1; $i<$max;$i++){
! warn " ".$subfield[$i];
! $subfield[$i]=substr($subfield[$i],3,1);
! warn " ".$subfield[$i];
! }
!
if ($record->fields($auth_tag_to_report)) {
! foreach my $subfieldcount (1..$#subfield){
! if ($record->field($auth_tag_to_report)->subfields($subfield[$subfieldcount])) {
! # warn "tag :".$tag." subfield: $subfield value : ".$record->field($tag)->subfield($subfield);
! push @tags, $auth_tag_to_report.$subfield[$subfieldcount];
! # warn "'".$tag.$subfield."' value :". $record->field($tag)->subfield($subfield);
push @and_or, "and";
push @excluding, "";
push @operator, "contains";
! push @value, $record->field($auth_tag_to_report)->subfield($subfield[$subfieldcount]);
}
}
+
+ # my $sth = $dbh->prepare("select tagfield,tagsubfield from auth_subfield_structure where tagfield=? and authtypecode=? and tab >= 0");
+ # $sth->execute($auth_tag_to_report,$authtypecode);
+ # warn " field $auth_tag_to_report exists";
+ # while (my ($tag,$subfield) = $sth->fetchrow){
+ # if ($record->field($tag)->subfields($subfield)) {
+ # # warn "tag :".$tag." subfield: $subfield value : ".$record->field($tag)->subfield($subfield);
+ # push @tags, $tag.$subfield;
+ # # warn "'".$tag.$subfield."' value :". $record->field($tag)->subfield($subfield);
+ # push @and_or, "and";
+ # push @excluding, "";
+ # push @operator, "contains";
+ # push @value, $record->field($tag)->subfield($subfield);
+ # }
+ # }
}
***************
*** 879,884 ****
# there is at least 1 result => return the 1st one
if ($nbresult) {
! warn "$nbresult => ".@$finalresult[0]->{authid},@$finalresult[0]->{summary};
! return @$finalresult[0]->{authid},@$finalresult[0]->{authid},@$finalresult[0]->{summary};
}
# no result, returns nothing
--- 904,909 ----
# there is at least 1 result => return the 1st one
if ($nbresult) {
! warn "$nbresult => ".@$finalresult[0]->{authid},$record->field($auth_tag_to_report)->subfield('a');
! return @$finalresult[0]->{authid},@$finalresult[0]->{authid},$record->field($auth_tag_to_report)->subfield('a');
}
# no result, returns nothing
***************
*** 900,903 ****
--- 925,931 ----
# $Id$
# $Log$
+ # Revision 1.13 2005/04/05 15:23:41 hdl
+ # Searching for double entries when adding a new authority.
+ #
# Revision 1.12 2005/04/05 09:58:48 hdl
# Adding double authority search before creating a new authority
More information about the Koha-cvs
mailing list