Permalink
Cannot retrieve contributors at this time
158 lines (105 sloc)
3.62 KB
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| ###################################################################### | |
| # | |
| # EPrints::MetaField::Id; | |
| # | |
| ###################################################################### | |
| # | |
| # | |
| ###################################################################### | |
| =pod | |
| =head1 NAME | |
| B<EPrints::MetaField::Id> - an identifier string | |
| =head1 DESCRIPTION | |
| Use Id fields whenever you are storing textual data that needs to be matched exactly (e.g. filenames). | |
| Characters that are not valid XML 1.0 code-points will be replaced with the Unicode replacement character. | |
| =over 4 | |
| =cut | |
| package EPrints::MetaField::Id; | |
| use EPrints::MetaField; | |
| @ISA = qw( EPrints::MetaField ); | |
| use strict; | |
| ###################################################################### | |
| =pod | |
| =item $val = $field->value_from_sql_row( $session, $row ) | |
| Shift and return the utf8 value of this field from the database input $row. | |
| =cut | |
| ###################################################################### | |
| sub value_from_sql_row | |
| { | |
| my( $self, $session, $row ) = @_; | |
| if( $session->{database}->{dbh}->{Driver}->{Name} eq "mysql" ) | |
| { | |
| utf8::decode( $row->[0] ) if defined($row) && defined($row->[0]); | |
| } | |
| return shift @$row; | |
| } | |
| =item @row = $field->sql_row_from_value( $session, $value ) | |
| Returns the value as an appropriate value for the database. | |
| Replaces invalid XML 1.0 code points with the Unicode substitution character (0xfffd), see http://www.w3.org/International/questions/qa-controls | |
| Values are truncated if they are longer than maxlength. | |
| =cut | |
| sub sql_row_from_value | |
| { | |
| my( $self, $session, $value ) = @_; | |
| return( undef ) if !defined $value; | |
| $value =~ s/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f-\x9f]/\x{fffd}/g; | |
| $value =~ s/^\s+//; | |
| $value =~ s/\s+$//; | |
| $value = substr( $value, 0, $self->{ "maxlength" } ); | |
| return( $value ); | |
| } | |
| sub get_property_defaults | |
| { | |
| my( $self ) = @_; | |
| return( | |
| $self->SUPER::get_property_defaults, | |
| match => "EX", | |
| merge => "ALL", | |
| ); | |
| } | |
| # id fields are searched whole, whether against the main table or in the index | |
| sub get_index_codes_basic | |
| { | |
| my( $self, $session, $value ) = @_; | |
| return( [], [], [] ) if !EPrints::Utils::is_set( $value ); | |
| return( [ $value ], [], [] ); | |
| } | |
| sub get_xml_schema_type | |
| { | |
| my( $self ) = @_; | |
| if ($self->property("maxlength") != $self->{field_defaults}->{maxlength}) { | |
| return $self->get_xml_schema_field_type; | |
| } | |
| else { | |
| return $self->{type}; | |
| } | |
| } | |
| sub render_xml_schema_type | |
| { | |
| my( $self, $session ) = @_; | |
| my $type = $session->make_element( "xs:simpleType", name => $self->get_xml_schema_type ); | |
| my $restriction = $session->make_element( "xs:restriction", base => "xs:string" ); | |
| $type->appendChild( $restriction ); | |
| my $length = $session->make_element( "xs:maxLength", value => $self->get_max_input_size ); | |
| $restriction->appendChild( $length ); | |
| return $type; | |
| } | |
| ###################################################################### | |
| 1; | |
| =head1 COPYRIGHT | |
| =for COPYRIGHT BEGIN | |
| Copyright 2000-2011 University of Southampton. | |
| =for COPYRIGHT END | |
| =for LICENSE BEGIN | |
| This file is part of EPrints L<http://www.eprints.org/>. | |
| EPrints is free software: you can redistribute it and/or modify it | |
| under the terms of the GNU Lesser General Public License as published | |
| by the Free Software Foundation, either version 3 of the License, or | |
| (at your option) any later version. | |
| EPrints is distributed in the hope that it will be useful, but WITHOUT | |
| ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
| FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public | |
| License for more details. | |
| You should have received a copy of the GNU Lesser General Public | |
| License along with EPrints. If not, see L<http://www.gnu.org/licenses/>. | |
| =for LICENSE END | |