]> git.evergreen-ils.org Git - Evergreen.git/blob - Open-ILS/src/sql/Pg/upgrade/0435.schema.template-add-field.sql
LP#1117808: Stamping upgrade scripts for extend use of merge profiles
[Evergreen.git] / Open-ILS / src / sql / Pg / upgrade / 0435.schema.template-add-field.sql
1
2 BEGIN;
3
4 INSERT INTO config.upgrade_log (version) VALUES ('0435'); -- miker
5
6 CREATE OR REPLACE FUNCTION vandelay.add_field ( target_xml TEXT, source_xml TEXT, field TEXT ) RETURNS TEXT AS $_$
7
8     use MARC::Record;
9     use MARC::File::XML (BinaryEncoding => 'UTF-8');
10     use strict;
11
12     my $target_xml = shift;
13     my $source_xml = shift;
14     my $field_spec = shift;
15
16     my $target_r = MARC::Record->new_from_xml( $target_xml );
17     my $source_r = MARC::Record->new_from_xml( $source_xml );
18
19     return $target_xml unless ($target_r && $source_r);
20
21     my @field_list = split(',', $field_spec);
22
23     my %fields;
24     for my $f (@field_list) {
25         $f =~ s/^\s*//; $f =~ s/\s*$//;
26         if ($f =~ /^(.{3})(\w*)(?:\[([^]]*)\])?$/) {
27             my $field = $1;
28             $field =~ s/\s+//;
29             my $sf = $2;
30             $sf =~ s/\s+//;
31             my $match = $3;
32             $match =~ s/^\s*//; $match =~ s/\s*$//;
33             $fields{$field} = { sf => [ split('', $sf) ] };
34             if ($match) {
35                 my ($msf,$mre) = split('~', $match);
36                 if (length($msf) > 0 and length($mre) > 0) {
37                     $msf =~ s/^\s*//; $msf =~ s/\s*$//;
38                     $mre =~ s/^\s*//; $mre =~ s/\s*$//;
39                     $fields{$field}{match} = { sf => $msf, re => qr/$mre/ };
40                 }
41             }
42         }
43     }
44
45     for my $f ( keys %fields) {
46         if ( @{$fields{$f}{sf}} ) {
47             for my $from_field ($source_r->field( $f )) {
48                 my @tos = $target_r->field( $f );
49                 if (!@tos) {
50                     my @new_fields = map { $_->clone } $source_r->field( $f );
51                     $target_r->insert_fields_ordered( @new_fields );
52                 } else {
53                     for my $to_field (@tos) {
54                         if (exists($fields{$f}{match})) {
55                             next unless (grep { $_ =~ $fields{$f}{match}{re} } $to_field->subfield($fields{$f}{match}{sf}));
56                         }
57                         my @new_sf = map { ($_ => $from_field->subfield($_)) } @{$fields{$f}{sf}};
58                         $to_field->add_subfields( @new_sf );
59                     }
60                 }
61             }
62         } else {
63             my @new_fields = map { $_->clone } $source_r->field( $f );
64             $target_r->insert_fields_ordered( @new_fields );
65         }
66     }
67
68     $target_xml = $target_r->as_xml_record;
69     $target_xml =~ s/^<\?.+?\?>$//mo;
70     $target_xml =~ s/\n//sgo;
71     $target_xml =~ s/>\s+</></sgo;
72
73     return $target_xml;
74
75 $_$ LANGUAGE PLPERLU;
76
77 COMMIT;
78