PDF::API2::Basic::PDF::Name - Inherits from L<PDF::API2::Basic::PDF::String>


PDF-API2 documentation Contained in the PDF-API2 distribution.

Index


Code Index:

NAME

Top

PDF::API2::Basic::PDF::Name - Inherits from PDF::API2::Basic::PDF::String and stores PDF names (things beginning with /)

METHODS

Top

PDF::API2::Basic::PDF::Name->from_pdf($string)

Creates a new string object (not a full object yet) from a given string. The string is parsed according to input criteria with escaping working, particular to Names.

$n->convert ($str, $pdf)

Converts a name into a string by removing the / and converting any hex munging.

$s->as_pdf ($pdf)

Returns a name formatted as PDF. $pdf is optional but should be the PDF File object for which the name is intended if supplied.

PDF::API2::Basic::PDF::Name->string_to_name ($str, $pdf)

Suitably encode the string $str for output in the File object $pdf (the exact format may depend on the version of $pdf).

Note: This function only encodes names properly for PDF version 1.2 and higher.

PDF::API2::Basic::PDF::Name->name_to_string ($str, $pdf)

Suitably decode the string $str as read from the File object $pdf (the exact decoding may depend on the version of $pdf). Principally, undo the hex encoding for PDF versions > 1.1.


PDF-API2 documentation Contained in the PDF-API2 distribution.
#=======================================================================
#
#   THIS IS A REUSED PERL MODULE, FOR PROPER LICENCING TERMS SEE BELOW:
#
#   Copyright Martin Hosken <Martin_Hosken@sil.org>
#
#   No warranty or expression of effectiveness, least of all regarding
#   anyone's safety, is implied in this software or documentation.
#
#   This specific module is licensed under the Perl Artistic License.
#
#=======================================================================
package PDF::API2::Basic::PDF::Name;

our $VERSION = '2.019';

use base 'PDF::API2::Basic::PDF::String';

use strict;

sub from_pdf {
    my ($class, $str, $pdf) = @_;
    my ($self) = $class->SUPER::from_pdf($str);

    $self->{'val'} = name_to_string($self->{'val'}, $pdf);
    return $self;
}

sub convert {
    my ($self, $str, $pdf) = @_;

    $str = name_to_string($str, $pdf);
    return $str;
}

sub as_pdf {
    my ($self, $pdf) = @_;
    my $str = $self->{'val'};

    $str = string_to_name($str, $pdf);
    return '/' . $str;
}


# Prior to PDF version 1.2, `#' was a literal character.  Embedded
# spaces were implicitly allowed in names as well but it would be best
# to ignore that (PDF reference 2nd edition, Appendix H, section 3.2.4.3).

# Technical Note: The code checking whether this is for version 1.1
# was commented out before it was entered into version control.  I'm
# not sure why.  (Steve Simms, 2010-08-28)

sub string_to_name ($;$) {
    my ($str, $pdf) = @_;
#   unless (defined($pdf) and $pdf->{' version'} < 2) { 
        $str =~ s|([\x00-\x20\x7f-\xff%()\[\]{}<>#/])|'#' . sprintf('%02X', ord($1))|oge; 
#   }
    return $str;
}

sub name_to_string ($;$) {
    my ($str, $pdf) = @_;
    $str =~ s|^/||o;

    unless (defined($pdf) and $pdf->{' version'} and $pdf->{' version'} < 2) {
        $str =~ s/#([0-9a-f]{2})/chr(hex($1))/oige;
    }

    return $str;
}

1;