4 use OpenILS::Application::Storage::CDBI;
5 use OpenILS::Application::Storage::CDBI::actor;
6 use OpenILS::Application::Storage::CDBI::biblio;
7 use OpenILS::Application::Storage::CDBI::config;
8 use OpenILS::Application::Storage::CDBI::metabib;
10 use vars qw/$fieldmap $VERSION/;
15 # To dump the Javascript version of the fieldmapper struct use the command:
17 # PERL5LIB=~/cvs/ILS/OpenSRF/src/perlmods/:~/cvs/ILS/Open-ILS/src/perlmods/ GEN_JS=1 perl -MOpenILS::Utils::Fieldmapper -e 'print "\n";'
19 # ... adjusted for your CVS sandbox, of course.
23 return () unless (defined $fieldmap);
24 return keys %$fieldmap;
28 return if (defined $fieldmap);
32 'Fieldmapper::actor::user' => { hint => 'au' },
33 'Fieldmapper::actor::org_unit' => { hint => 'aou' },
34 'Fieldmapper::actor::org_unit_type' => { hint => 'aout' },
35 'Fieldmapper::biblio::record_node' => { hint => 'brn',
36 proto_fields => { children => 1 } },
37 'Fieldmapper::biblio::record_entry' => { hint => 'bre' },
38 'Fieldmapper::biblio::record_mods' => { hint => 'brm' },
39 'Fieldmapper::biblio::record_marc' => { hint => 'brx' },
40 'Fieldmapper::config::bib_source' => { hint => 'cbs' },
41 'Fieldmapper::config::metabib_field' => { hint => 'cmf' },
42 'Fieldmapper::metabib::metarecord' => { hint => 'mmr' },
43 'Fieldmapper::metabib::title_field_entry' => { hint => 'mmr' },
44 'Fieldmapper::metabib::author_field_entry' => { hint => 'mmr' },
45 'Fieldmapper::metabib::subject_field_entry' => { hint => 'mmr' },
46 'Fieldmapper::metabib::keyword_field_entry' => { hint => 'mmr' },
47 'Fieldmapper::metabib::full_rec' => { hint => 'mmr' },
50 #-------------------------------------------------------------------------------
51 # Now comes the evil! Generate classes
53 for my $pkg ( keys %$fieldmap ) {
54 (my $cdbi = $pkg) =~ s/^Fieldmapper:://o;
58 use base 'Fieldmapper';
61 $$fieldmapp{$pkg}{cdbi} = $cdbi;
64 for my $vfield ( qw/isnew ischanged isdeleted/ ) {
65 $$fieldmap{$pkg}{fields}{$vfield} = { position => $pos, virtual => 1 };
69 if (exists $$fieldmap{$pkg}{proto_fields}) {
70 for my $pfield ( keys %{ $$fieldmap{$pkg}{proto_fields} } ) {
71 $$fieldmap{$pkg}{fields}{$pfield} = { position => $pos, virtual => $$fieldmap{$pkg}{proto_fields}{$pfield} };
76 for my $col ( $cdbi->columns('All') ) {
77 $$fieldmap{$pkg}{fields}{$col} = { position => $pos, virtual => 0 };
81 JSON->register_class_hint(
82 hint => $pkg->json_hint,
89 print Fieldmapper->javascript() if ($ENV{GEN_JS});
95 $value = [] unless (defined $value);
96 return bless $value => $self->class_name;
100 my $class_name = shift;
101 return 'var fieldmap = ' . JSON->perl2JSON($fieldmap) . ';'
109 (my $field = $AUTOLOAD) =~ s/^.*://o;
110 my $class_name = $obj->class_name;
113 if ($field =~ /^clear_/o) {
115 *{$obj->class_name."::$field"} = sub {
117 $self->[$pos] = undef;
121 return $obj->$field();
124 die "No field by the name $field in $class_name!"
125 unless (exists $$fieldmap{$class_name}{fields}{$field});
127 my $pos = $$fieldmap{$class_name}{fields}{$field}{position};
130 *{$obj->class_name."::$field"} = sub {
133 $self->[$pos] = $new_val if (defined $new_val);
134 return $self->[$pos];
137 return $obj->$field($value);
141 my $class_name = shift;
142 return ref($class_name) || $class_name;
147 my $class_name = $self->class_name;
148 my $fields = $$fieldmap{$class_name}{fields};
151 !$$fields{$_}{virtual}
152 } sort {$$fields{$a}{position} <=> $$fields{$b}{position}} keys %$fields;
159 return $fieldmap->{$self->class_name}->{api_level};
164 return $fieldmap->{$self->class_name}->{hint};