# static criteria scoring
#----------------------------------
$marc->{misc_score} = 999;
+ $marc->{age_score} = 999999999999;
+
# -1 if 008 has been padded, -2 if it doesn't exist
if ($marc->{tag008})
{ $marc->{misc_score}-- if ($marc->{tag008} =~ /\|$/) }
$marc->{misc_score}--
if (defined $marc->{tag300a} and $marc->{tag300a} =~ /copy/i);
+ # subtract record id if we want older records to win
+ #$marc->{age_score} -= $marc->{id} unless ($conf->{newwins});
+ # handle arbitrary adjustments
+ $marc->{age_score} = 1;
+ if ($conf->{'arbitrarily-lose-above'}) {
+ $marc->{age_score} = 0
+ if ($marc->{id} >= $conf->{'arbitrarily-lose-above'});
+ }
+ if ($conf->{'arbitrarily-lose-below'}) {
+ $marc->{age_score} = 0
+ if ($marc->{id} <= $conf->{'arbitrarily-lose-below'});
+ }
+
#----------------------------------
# dynamic calculated scoring
#----------------------------------
}
$json .= 'misc:' . $marc->{misc_score} . '}';
- my $compact = join('', $marc->{misc_score}, @score);
+ my $compact = join('', $marc->{age_score}, $marc->{misc_score}, @score);
$marc->{score} = "$compact\t$json";
}
'tag|t=s',
'fingerprints=s',
'scores=s',
+ 'arbitrarily-lose-above=i',
+ 'arbitrarily-lose-below=i',
+ 'newwins',
'quiet|q',
'help|h',
);
--scores=LIST Scores to calculate, comma separated
Default: oclc,dlc,num_650,num_tags,enc_level
+ --newwins New record IDs score higher (default is old wins)
+ --arbitrarily-lose-above
+ --arbitrarily-lose-below
+ --arbitrarily-decrease-score-by
+ Modify fingerprint scoring of records whose EG id is above or below a
+ given value, inclusive (so 5 is <= 5 or >= 5) such that they lose.
--marctype=TYPE Defaults to 'XML'
HELP