[Koha-cvs] CVS: koha/C4 AuthoritiesMarc.pm,1.9.2.2,1.9.2.3

Paul POULAIN tipaul at users.sourceforge.net
Thu Apr 28 10:45:51 CEST 2005


Update of /cvsroot/koha/koha/C4
In directory sc8-pr-cvs1.sourceforge.net:/tmp/cvs-serv8908/C4

Modified Files:
      Tag: rel_2_2
	AuthoritiesMarc.pm 
Log Message:
porting FindDuplicate feature for authorities from HEAD to rel_2_2, works correctly now.

Index: AuthoritiesMarc.pm
===================================================================
RCS file: /cvsroot/koha/koha/C4/AuthoritiesMarc.pm,v
retrieving revision 1.9.2.2
retrieving revision 1.9.2.3
diff -C2 -r1.9.2.2 -r1.9.2.3
*** AuthoritiesMarc.pm	28 Feb 2005 14:03:13 -0000	1.9.2.2
--- AuthoritiesMarc.pm	28 Apr 2005 08:45:33 -0000	1.9.2.3
***************
*** 52,55 ****
--- 52,56 ----
  	&MARCaddword &MARCdelword
  	&char_decode
+ 	&FindDuplicate
   );
  
***************
*** 75,79 ****
  	# "Normal" statements
  	# quote marc fields/subfields
! 	for (my $i=0;$i<$#{$tags};$i++) {
  		if (@$tags[$i]) {
  			@$tags[$i] = $dbh->quote(@$tags[$i]);
--- 76,80 ----
  	# "Normal" statements
  	# quote marc fields/subfields
! 	for (my $i=0;$i<=$#{$tags};$i++) {
  		if (@$tags[$i]) {
  			@$tags[$i] = $dbh->quote(@$tags[$i]);
***************
*** 845,848 ****
--- 846,900 ----
  }
  
+ sub FindDuplicate {
+ 	my ($record,$authtypecode)=@_;
+ 	warn "IN for ".$record->as_formatted;
+ 	my $dbh = C4::Context->dbh;
+ 
+ #	warn "".$record->as_formatted;
+ 	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;
+ 	# 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)) {
+ 		my $sth = $dbh->prepare("select tagfield,tagsubfield from auth_subfield_structure where tagfield=? and authtypecode=? ");
+ 		$sth->execute($auth_tag_to_report,$authtypecode);
+ #		warn " field $auth_tag_to_report exists";
+ 		while (my ($tag,$subfield) = $sth->fetchrow){
+ 			if ($record->field($tag)->subfield($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, "=";
+ 				push @value, $record->field($tag)->subfield($subfield);
+ 			}
+ 		}
+  	}
+  
+ 	my ($finalresult,$nbresult) = authoritysearch($dbh,\@tags,\@and_or,\@excluding,\@operator,\@value,0,10,$authtypecode);
+ 	# there is at least 1 result => return the 1st one
+ 	if ($nbresult) {
+ 		warn "XXXXX $nbresult => ".@$finalresult[0]->{authid},@$finalresult[0]->{summary};
+ 		return @$finalresult[0]->{authid},@$finalresult[0]->{summary};
+ 	}
+ 	# no result, returns nothing
+ 	return;
+ }
+ 
+ 
  END { }       # module clean-up code here (global destructor)
  
***************
*** 859,862 ****
--- 911,917 ----
  # $Id$
  # $Log$
+ # Revision 1.9.2.3  2005/04/28 08:45:33  tipaul
+ # porting FindDuplicate feature for authorities from HEAD to rel_2_2, works correctly now.
+ #
  # Revision 1.9.2.2  2005/02/28 14:03:13  tipaul
  # * adding search on "main entry" (ie $a subfield) on a given authority (the "search everywhere" field is still here).





More information about the Koha-cvs mailing list