my @subfields = $field->subfields();
my @subfield_array;
foreach my $subfield (@subfields) {
- if ( !defined($tagslib)
- || $tagslib->{$fieldtag}->{ @$subfield[0] }->{'tab'} >= 0 )
+ if (
+ !defined($tagslib)
+ || ( defined $tagslib->{$fieldtag}
+ && defined $tagslib->{$fieldtag}->{ @$subfield[0] }
+ && defined $tagslib->{$fieldtag}->{ @$subfield[0] }->{'tab'}
+ && $tagslib->{$fieldtag}->{ @$subfield[0] }->{'tab'} >= 0 )
+ )
{
push @subfield_array,
{
}
- if ( !defined($tagslib) || @subfield_array )
+ if (
+ (
+ !defined($tagslib) || ( defined $tagslib->{$fieldtag}
+ && defined $tagslib->{$fieldtag}->{'tab'}
+ && $tagslib->{$fieldtag}->{'tab'} >= 0 )
+ )
+ && @subfield_array
+ )
{
push @array,
{
return int(rand(1000000));
}
+=head2 getAuthorityAuthorizedHeading
+
+Retrieve the authorized heading from a MARC authority record
+
+=cut
+
+sub getAuthorityAuthorizedHeading {
+ my ( $record, $schema ) = @_;
+ return unless ( ref $record eq 'MARC::Record' );
+ if ( $schema eq 'unimarc' ) {
+
+ # construct UNIMARC summary, that is quite different from MARC21 one
+ # accepted form
+ foreach my $field ( $record->field('2..') ) {
+ return $field->as_string('abcdefghijlmnopqrstuvwxyz');
+ }
+ }
+ else {
+ foreach my $field ( $record->field('1..') ) {
+ my $tag = $field->tag();
+ next if "152" eq $tag;
+
+ # FIXME - 152 is not a good tag to use
+ # in MARC21 -- purely local tags really ought to be
+ # 9XX
+ if ( $tag eq '100' ) {
+ return $field->as_string('abcdefghjklmnopqrstvxyz68');
+ }
+ elsif ( $tag eq '110' ) {
+ return $field->as_string('abcdefghklmnoprstvxyz68');
+ }
+ elsif ( $tag eq '111' ) {
+ return $field->as_string('acdefghklnpqstvxyz68');
+ }
+ elsif ( $tag eq '130' ) {
+ return $field->as_string('adfghklmnoprstvxyz68');
+ }
+ elsif ( $tag eq '148' ) {
+ return $field->as_string('abvxyz68');
+ }
+ elsif ( $tag eq '150' ) {
+ return $field->as_string('abvxyz68');
+ }
+ elsif ( $tag eq '151' ) {
+ return $field->as_string('avxyz68');
+ }
+ elsif ( $tag eq '155' ) {
+ return $field->as_string('abvxyz68');
+ }
+ elsif ( $tag eq '180' ) {
+ return $field->as_string('vxyz68');
+ }
+ elsif ( $tag eq '181' ) {
+ return $field->as_string('vxyz68');
+ }
+ elsif ( $tag eq '182' ) {
+ return $field->as_string('vxyz68');
+ }
+ elsif ( $tag eq '185' ) {
+ return $field->as_string('vxyz68');
+ }
+ else {
+ return $field->as_string();
+ }
+ }
+ }
+ return;
+}
+
1;