r1452 - in packages/libpdf-api2-perl/trunk: . debian examples
lib/PDF lib/PDF/API2 lib/PDF/API2/Basic/PDF
lib/PDF/API2/Resource lib/PDF/API2/Resource/CIDFont
lib/PDF/API2/Resource/CIDFont/TrueType lib/PDF/API2/Resource/Font
lib/PDF/API2/Resource/Font/CoreFont
lib/PDF/API2/Resource/XObject/Image
Gunnar Wolf
gwolf at costa.debian.org
Mon Oct 24 17:15:00 UTC 2005
Author: gwolf
Date: 2005-10-24 17:14:19 +0000 (Mon, 24 Oct 2005)
New Revision: 1452
Modified:
packages/libpdf-api2-perl/trunk/CHANGELOG
packages/libpdf-api2-perl/trunk/META.yml
packages/libpdf-api2-perl/trunk/debian/changelog
packages/libpdf-api2-perl/trunk/examples/020_corefonts
packages/libpdf-api2-perl/trunk/examples/025_unifonts
packages/libpdf-api2-perl/trunk/lib/PDF/API2.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Basic/PDF/File.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Content.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/IOString.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/BaseFont.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/CIDFont.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/CIDFont/TrueType.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/CIDFont/TrueType/FontFile.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/BdFont.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/CoreFont.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/CoreFont/courier.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/Postscript.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/UniFont.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/XObject/Image/JPEG.pm
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/uniglyph.txt
packages/libpdf-api2-perl/trunk/lib/PDF/API2/Version.pm
Log:
New upstream release
Modified: packages/libpdf-api2-perl/trunk/CHANGELOG
===================================================================
--- packages/libpdf-api2-perl/trunk/CHANGELOG 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/CHANGELOG 2005-10-24 17:14:19 UTC (rev 1452)
@@ -1,3 +1,114 @@
+2005-10-21 23:42 fredo
+
+ * lib/PDF/API2/Basic/PDF/File.pm: speedup reading large
+ dictionaries/structs
+
+2005-10-21 23:42 fredo
+
+ * lib/PDF/API2/IOString.pm: fixed tell tier
+
+2005-10-21 21:52 fredo
+
+ * lib/PDF/API2/Basic/PDF/File.pm: fixed readxrtr to be more strict
+ to the latest pdf-spec
+
+2005-10-21 21:51 fredo
+
+ * lib/PDF/API2.pm: fixed proc_pages
+
+2005-10-20 23:06 fredo
+
+ * lib/PDF/API2.pm: documented '-dokern' option for ttfonts
+
+2005-10-20 23:04 fredo
+
+ * lib/PDF/API2/Resource/: CIDFont/TrueType.pm, CIDFont.pm,
+ CIDFont/TrueType/FontFile.pm: added handling of optional kerning
+
+2005-10-20 01:05 fredo
+
+ * lib/PDF/API2/Resource/Font/Postscript.pm: silenced 'cannot parse'
+ since it is usually no error
+
+2005-10-19 23:23 fredo
+
+ * lib/PDF/API2.pm: documented '-dokern' option for core- and
+ psfonts
+
+2005-10-19 21:12 fredo
+
+ * lib/PDF/API2/Resource/Font/: Postscript.pm, CoreFont.pm: added
+ handling of optional kerning
+
+2005-10-19 21:08 fredo
+
+ * lib/PDF/API2/Resource/UniFont.pm: added extended typographic text
+ handling call
+
+2005-10-19 21:07 fredo
+
+ * lib/PDF/API2/Resource/Font.pm: added handling of composites in
+ automap
+
+2005-10-19 21:06 fredo
+
+ * lib/PDF/API2/Resource/BaseFont.pm: added handling of kerning
+
+2005-10-19 21:05 fredo
+
+ * lib/PDF/API2/IOString.pm: ...
+
+2005-10-19 21:04 fredo
+
+ * lib/PDF/API2/Content.pm: added extended typographic text handling
+ call
+
+2005-10-02 01:38 fredo
+
+ * lib/PDF/API2/Resource/Font/Postscript.pm: added kerning+composite
+ parsing added nonembedding check
+
+2005-10-02 00:41 fredo
+
+ * lib/PDF/API2/Resource/Font/: BdFont.pm, CoreFont.pm,
+ Postscript.pm: fixed font-naming race condition for multiple
+ document updates
+
+2005-10-02 00:30 fredo
+
+ * lib/PDF/API2/Resource/CIDFont/TrueType.pm: fixed font-naming race
+ condition for multiple document updates
+
+2005-10-02 00:10 fredo
+
+ * lib/PDF/API2/Content.pm: added more docs for textlabel
+
+2005-09-28 19:02 fredo
+
+ * lib/PDF/API2/Resource/XObject/Image/JPEG.pm: fixed iostring
+ handling
+
+2005-09-28 19:00 fredo
+
+ * lib/PDF/API2/Resource/Font/CoreFont/courier.pm: added composites
+
+2005-09-28 19:00 fredo
+
+ * lib/PDF/API2/Resource/uniglyph.txt: added combiners
+
+2005-09-26 22:07 fredo
+
+ * lib/PDF/API2/Resource/Font/CoreFont.pm: added fontmetric stub
+
+2005-09-26 22:06 fredo
+
+ * lib/PDF/API2/Resource/Font.pm: removed composite glyphs from
+ automap
+
+2005-09-26 21:28 fredo
+
+ * lib/PDF/API2/Resource/Font/CoreFont/courier.pm: no message
+
2005-09-12 18:56 fredo
* lib/PDF/API2/Resource/Font/: CoreFont.pm, CoreFont/bankgothic.pm,
Modified: packages/libpdf-api2-perl/trunk/META.yml
===================================================================
--- packages/libpdf-api2-perl/trunk/META.yml 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/META.yml 2005-10-24 17:14:19 UTC (rev 1452)
@@ -1,7 +1,7 @@
# http://module-build.sourceforge.net/META-spec.html
#XXXXXXX This is a prototype!!! It will change in the future!!! XXXXX#
name: PDF-API2
-version: 0.46
+version: 0.49
version_from: lib/PDF/API2/Version.pm
installdirs: site
requires:
Modified: packages/libpdf-api2-perl/trunk/debian/changelog
===================================================================
--- packages/libpdf-api2-perl/trunk/debian/changelog 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/debian/changelog 2005-10-24 17:14:19 UTC (rev 1452)
@@ -1,3 +1,9 @@
+libpdf-api2-perl (0.49-1) unstable; urgency=low
+
+ * New upstream release
+
+ -- Gunnar Wolf <gwolf at debian.org> Mon, 24 Oct 2005 12:08:42 -0500
+
libpdf-api2-perl (0.46-1) unstable; urgency=low
* New upstream release
Modified: packages/libpdf-api2-perl/trunk/examples/020_corefonts
===================================================================
--- packages/libpdf-api2-perl/trunk/examples/020_corefonts 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/examples/020_corefonts 2005-10-24 17:14:19 UTC (rev 1452)
@@ -41,8 +41,7 @@
my $sx=33;
my $sy=45;
my $fx=20;
-
-foreach $fn (qw(
+ at fns=qw{
Helvetica
Helvetica-Oblique
Helvetica-Bold
@@ -72,9 +71,29 @@
verdanabolditalic
wingdings
webdings
-))
+};
+
+ at ecs=qw{
+ latin1
+ latin2
+ latin3
+ latin4
+ latin5
+ latin6
+ latin7
+ latin8
+ latin9
+ latin10
+};
+
+if(scalar @ARGV)
{
- foreach $ec (qw[latin1 latin2 latin3 latin4 latin5 latin6 latin7 latin8 latin9 latin10])
+ @fns=@ARGV;
+}
+
+foreach $fn (@fns)
+{
+ foreach $ec (qw{ latin1 })
{
$pdf=PDF::API2->new;
@@ -145,7 +164,6 @@
$pdf->end();
}
- last;
}
exit;
Modified: packages/libpdf-api2-perl/trunk/examples/025_unifonts
===================================================================
--- packages/libpdf-api2-perl/trunk/examples/025_unifonts 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/examples/025_unifonts 2005-10-24 17:14:19 UTC (rev 1452)
@@ -102,28 +102,28 @@
'KozGo-Italic + Georgia-Italic'=>$u3
);
-$y=800;
-$page = $api->page;
-$gfx = $page->gfx;
-
foreach my $fontname ('KozMin','KozMin-Bold + Times','KozGo-Italic + Trebuchet-Italic','KozGo-Italic + Georgia-Italic')
{
+ $y=800;
+
+ $page = $api->page;
+ $gfx = $page->gfx;
+ delete $gfx->{Filter};
my $font=$fonts{$fontname};
$uw->{widthobj}=$font;
seek(DATA,$start,0);
binmode(DATA,':raw');
- #delete $gfx->{Filter};
- $i=0;
-
- $gfx->textlabel(100,$y,$helv,10,$fontname,-color=>'darkred');
- $y-=15;
- $line=<DATA>;
- $line=~s|[\012\015]+$||go;
- $gfx->textlabel(100,$y,$font,10,$line,-hspace=>80);
- $y-=20;
+ $gfx->textlabel(50,$y,$helv,10,$fontname,-color=>'darkred');
+ foreach (1..45)
+ {
+ $y-=15;
+ $line=<DATA>;
+ $line=~s|[\012\015]+$||go;
+ $gfx->textlabel(50,$y,$font,10,$line,-hspace=>80);
+ }
}
$api->saveas("$0.pdf");
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Basic/PDF/File.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Basic/PDF/File.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Basic/PDF/File.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -23,7 +23,7 @@
# This specific module is licensed under the Perl Artistic License.
#
#
-# $Id: File.pm,v 1.19 2005/06/02 12:59:43 fredo Exp $
+# $Id: File.pm,v 1.21 2005/10/21 21:42:56 fredo Exp $
#
#=======================================================================
package PDF::API2::Basic::PDF::File;
@@ -178,6 +178,7 @@
$t =~ s|::|/|og;
require "$t.pm";
}
+ $PDF::API2::Basic::PDF::File::readDebug=0;
}
@@ -301,9 +302,12 @@
$fh->seek(0, 2); # go to end of file
$end = $fh->tell();
$self->{' epos'} = $end;
- if (!$fh->seek(($end > 1024 ? $end - 1024 : 0, 0)))
+# if (!$fh->seek(($end > 1024 ? $end - 1024 : 0, 0)))
+# { die "Seek failed when reading PDF file $fname"; }
+# $fh->read($buf, 1024);
+ if (!$fh->seek(($end > 64 ? $end - 64 : 0, 0)))
{ die "Seek failed when reading PDF file $fname"; }
- $fh->read($buf, 1024);
+ $fh->read($buf, 64);
if ($buf !~ m/startxref$cr([0-9]+)$cr\%\%eof.*?$/oi)
{ die "Malformed PDF file $fname"; }
$xpos = $1;
@@ -352,8 +356,10 @@
$fh->seek(0, 2); # go to end of file
$end = $fh->tell();
$self->{' epos'} = $end;
- $fh->seek($end - 1024, 0);
- $fh->read($buf, 1024);
+# $fh->seek($end - 1024, 0);
+# $fh->read($buf, 1024);
+ $fh->seek($end - 64, 0);
+ $fh->read($buf, 64);
if ($buf !~ m/startxref$cr\s*([0-9]+)$cr\%\%eof.*?/oi)
{ die "Malformed PDF file $fname"; }
$xpos = $1;
@@ -567,12 +573,14 @@
my ($fh) = $self->{' INFILE'};
my ($res, $key, $value, $k);
- $str = update($fh, $str);
+ #$str = update($fh, $str);
+ updateRef($fh, \$str);
if ($str =~ m/^<</so)
{
$str = substr ($str, 2);
- $str = update($fh, $str);
+ #$str = update($fh, $str);
+ updateRef($fh, \$str);
$res = PDFDict();
while ($str !~ m/^>>/o) {
@@ -594,10 +602,12 @@
($value, $str) = $self->readval($str, %opts);
$res->{null} = $value;
}
- $str = update($fh, $str); # thanks gareth.jones at stud.man.ac.uk
+ #$str = update($fh, $str); # thanks gareth.jones at stud.man.ac.uk
+ updateRef($fh, \$str); # thanks gareth.jones at stud.man.ac.uk
}
$str =~ s/^>>//o;
- $str = update($fh, $str);
+ #$str = update($fh, $str);
+ updateRef($fh, \$str);
# streams can't be followed by a lone carriage-return.
# fredo: yes they can !!! -- use the MacOS Luke.
if (($str =~ s/^stream(?:(?:\015\012)|\012|\015)//o)
@@ -618,7 +628,8 @@
$value .= substr($str, 0, $k);
$res->{' stream'} = $value;
$res->{' nofilt'} = 1;
- $str = update($fh, $str, 1); # tell update we are in-stream and only need an endstream
+ #$str = update($fh, $str, 1); # tell update we are in-stream and only need an endstream
+ updateRef($fh, \$str, 1); # tell update we are in-stream and only need an endstream
#$str =~ s/^endstream//o; # we cannot regexpr here since we need the first endstream only
# so we do the following:
my $wh = index($str,'endstream');
@@ -630,7 +641,8 @@
if (defined $res->{'Type'} && defined $types{$res->{'Type'}->val});
# gdj: FIXME: if any of the ws chars were crs, then the whole
# string might not have been read.
- } elsif ($str =~ m/^([0-9]+)$ws_char+([0-9]+)$ws_char+R/so) # objind
+ }
+ elsif ($str =~ m/^([0-9]+)$ws_char+([0-9]+)$ws_char+R/so) # objind
{
$k = $1;
$value = $2;
@@ -646,7 +658,8 @@
$res->{' realised'} = 0;
# gdj: FIXME: if any of the ws chars were crs, then the whole
# string might not have been read.
- } elsif ($str =~ m/^([0-9]+)$ws_char+([0-9]+)$ws_char+obj/so) # object data
+ }
+ elsif ($str =~ m/^([0-9]+)$ws_char+([0-9]+)$ws_char+obj/so) # object data
{
my ($obj);
$k = $1;
@@ -661,7 +674,8 @@
$self->add_obj($res, $k, $value);
$res->{' realised'} = 1;
}
- $str = update($fh, $str); # thanks to kundrat at kundrat.sk
+ #$str = update($fh, $str); # thanks to kundrat at kundrat.sk
+ updateRef($fh, \$str); # thanks to kundrat at kundrat.sk
$str =~ s/^endobj//o;
} elsif ($str =~ m|^/($reg_char+)|so) # name
{
@@ -711,39 +725,47 @@
}
$res = PDF::API2::Basic::PDF::String->from_pdf($value);
- } elsif ($str =~ m/^</o) # hex-string
+ }
+ elsif ($str =~ m/^</o) # hex-string
{
$str =~ s/^<//o;
$fh->read($str, 255, length($str)) while (0 > index( $str, '>' ));
($value, $str) = ($str =~ /^(.*?)>(.*?)$/so);
$res = PDF::API2::Basic::PDF::String->from_pdf("<" . $value . ">");
- } elsif ($str =~ m/^\[/o) # array
+ }
+ elsif ($str =~ m/^\[/o) # array
{
$str =~ s/^\[//o;
- $str = update($fh, $str);
+ #$str = update($fh, $str);
+ updateRef($fh, \$str);
$res = PDFArray();
while ($str !~ m/^\]/o)
{
($value, $str) = $self->readval($str, %opts);
$res->add_elements($value);
- $str = update($fh, $str); # str might just be exhausted!
+ #$str = update($fh, $str); # str might just be exhausted!
+ updateRef($fh, \$str); # str might just be exhausted!
}
$str =~ s/^\]//o;
- } elsif ($str =~ m/^(true|false)$irreg_char/o) # boolean
+ }
+ elsif ($str =~ m/^(true|false)$irreg_char/o) # boolean
{
$value = $1;
$str =~ s/^(?:true|false)//o;
$res = PDF::API2::Basic::PDF::Bool->from_pdf($value);
- } elsif ($str =~ m/^([+-.0-9]+)$irreg_char/o) # number
+ }
+ elsif ($str =~ m/^([+-.0-9]+)$irreg_char/o) # number
{
$value = $1;
$str =~ s/^([+-.0-9]+)//o;
$res = PDF::API2::Basic::PDF::Number->from_pdf($value);
- } elsif ($str =~ m/^null$irreg_char/o)
+ }
+ elsif ($str =~ m/^null$irreg_char/o)
{
$str =~ s/^null//o;
$res = PDF::API2::Basic::PDF::Null->new;
- } else
+ }
+ else
{
# finally give up
die "Can't parse `$str' near " . ($fh->tell()) . " length " . length($str) . ".";
@@ -1087,24 +1109,27 @@
sub update
{
my ($fh, $str, $instream) = @_;
-
+ print STDERR "fpos=".tell($fh)." strlen=".length($str)."\n" if($readDebug);
if($instream) {
# we are inside a (possible binary) stream
# so we fetch data till we see an 'endstream'
# -- fredo/2004-09-03
while ($str !~ m/endstream/o && !$fh->eof)
{
+ print STDERR "fpos=".tell($fh)." strlen=".length($str)."\n" if($readDebug);
$fh->read($str, 314, length($str));
}
} else {
$str =~ s/^$ws_char*//o;
while ($str !~ m/$cr/o && !$fh->eof)
{
+ print STDERR "fpos=".tell($fh)." strlen=".length($str)."\n" if($readDebug);
$fh->read($str, 314, length($str));
$str =~ s/^$ws_char*//so;
}
while ($str =~ m/^\%/o) # restructured by fredo/2003-03-23
{
+ print STDERR "fpos=".tell($fh)." strlen=".length($str)."\n" if($readDebug);
$fh->read($str, 314, length($str)) while ($str !~ m/$cr/o && !$fh->eof);
$str =~ s/^\%[^\015\012]+$ws_char*//so; # fixed for reportlab -- fredo
}
@@ -1113,7 +1138,42 @@
return $str;
}
+sub updateRef
+{
+ my ($fh, $str, $instream) = @_;
+ my $inlen=16; my $inoff=1;
+ print STDERR "fpos=".tell($fh)." strlen=".length($$str)."\n" if($readDebug);
+ if($instream) {
+ # we are inside a (possible binary) stream
+ # so we fetch data till we see an 'endstream'
+ # -- fredo/2004-09-03
+ while ($$str !~ m/endstream/o && !$fh->eof)
+ {
+ print STDERR "fpos=".tell($fh)." strlen=".length($$str)."\n" if($readDebug);
+ $fh->read($$str, 314, length($$str));
+ }
+ } else {
+ $$str =~ s/^$ws_char*//o;
+ while ($$str !~ m/$cr/o && !$fh->eof && length($$str) < 16000)
+ {
+ print STDERR "fpos=".tell($fh)." strlen=".length($$str)."\n" if($readDebug);
+ $fh->read($$str, $inlen, length($$str));
+ $$str =~ s/^$ws_char*//so;
+ $inlen+=$inoff;
+ }
+ while ($$str =~ m/^\%/o) # restructured by fredo/2003-03-23
+ {
+ print STDERR "fpos=".tell($fh)." strlen=".length($$str)."\n" if($readDebug);
+ $fh->read($$str, $inlen, length($$str)) while ($$str !~ m/$cr/o && !$fh->eof);
+ $$str =~ s/^\%[^\015\012]+$ws_char*//so; # fixed for reportlab -- fredo
+ $inlen+=$inoff;
+ }
+ }
+ return undef;
+}
+
+
=head2 $objind = $p->test_obj($num, $gen)
Tests the cache to see whether an object reference (which may or may not have
@@ -1180,7 +1240,10 @@
$fh->read($buf, 20 * $xnum - $xdiff + 15, $xdiff);
while ($xnum-- > 0 && $buf =~ s/^0*([0-9]*)$ws_char+0*([0-9]+)$ws_char+([nf])$cr//o)
- { $xlist->{$xmin++} = [$1, $2, $3]; }
+ {
+ $xlist->{$xmin} = [$1, $2, $3] unless(exists $xlist->{$xmin});
+ $xmin++;
+ }
}
if ($buf !~ /^trailer$cr/oi)
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Content.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Content.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Content.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -27,7 +27,7 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
#
-# $Id: Content.pm,v 1.38 2005/06/17 19:43:46 fredo Exp $
+# $Id: Content.pm,v 1.40 2005/10/19 19:04:43 fredo Exp $
#
#=======================================================================
@@ -47,7 +47,7 @@
@ISA = qw(PDF::API2::Basic::PDF::Dict);
- ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.38 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/06/17 19:43:46 $
+ ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.40 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/10/19 19:04:43 $
}
@@ -1824,14 +1824,14 @@
$self->matrix_update($wd,0);
}
my $ulxy1=[$self->textpos2];
- if($self->{' font'}->isvirtual)
- {
+ #if($self->{' font'}->isvirtual)
+ #{
$self->add($self->{' font'}->text($text,$self->{' fontsize'}));
- }
- else
- {
- $self->add($self->{' font'}->text($text),'Tj');
- }
+ #}
+ #else
+ #{
+ # $self->add($self->{' font'}->text($text),'Tj');
+ #}
$wd=$self->advancewidth($text);
$self->matrix_update($wd,0);
@@ -2050,7 +2050,8 @@
=item $width = $txt->textlabel $x, $y, $font, $size, $text, %options
-Applys text with options, but without teststart/end and optionally returns the width of the given text.
+Applys text with options, but without teststart/end
+and optionally returns the width of the given text.
B<Example:>
@@ -2059,12 +2060,19 @@
-rotate => -30,
-color => '#FF0000',
-hspace => 120,
- -center => 1,
+ -align => 'center',
);
+ $t->textlabel(500,500,$myfont,20,'Page Header',
+ -rotate => 30,
+ -color => '#0000FF',
+ -hspace => 80,
+ -align => 'right',
+ );
=cut
-sub textlabel {
+sub textlabel
+{
my ($self,$x,$y,$font,$size,$text,%opts,$wht) = @_;
my %trans_opts=( -translate => [$x,$y] );
my %text_state=();
@@ -2090,11 +2098,16 @@
$self->wordspace($opts{-wordspace}) if($opts{-wordspace});
$self->render($opts{-render}) if($opts{-render});
- if($opts{-right} || $opts{-align}=~/^r/i) {
+ if($opts{-right} || $opts{-align}=~/^r/i)
+ {
$wht = $self->text_right($text,%opts);
- } elsif($opts{-center} || $opts{-align}=~/^c/i) {
+ }
+ elsif($opts{-center} || $opts{-align}=~/^c/i)
+ {
$wht = $self->text_center($text,%opts);
- } else {
+ }
+ else
+ {
$wht = $self->text($text,%opts);
}
@@ -2156,6 +2169,12 @@
=head1 HISTORY
$Log: Content.pm,v $
+ Revision 1.40 2005/10/19 19:04:43 fredo
+ added extended typographic text handling call
+
+ Revision 1.39 2005/10/01 22:10:57 fredo
+ added more docs for textlabel
+
Revision 1.38 2005/06/17 19:43:46 fredo
fixed CPAN modulefile versioning (again)
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/IOString.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/IOString.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/IOString.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -33,14 +33,14 @@
# Original Copyright 1998-2000 Gisle Aas.
# modified by Alfred Reibenschuh <areibens at cpan.org> for PDF::API2
#
-# $Id: IOString.pm,v 1.12 2005/06/17 19:43:46 fredo Exp $
+# $Id: IOString.pm,v 1.14 2005/10/21 21:42:15 fredo Exp $
#
#=======================================================================
package PDF::API2::IOString;
require 5.006;
use vars qw($VERSION $DEBUG $IO_CONSTANTS);
- ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.12 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/06/17 19:43:46 $
+ ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.14 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/10/21 21:42:15 $
use Symbol ();
use FileHandle;
no warnings qw[ deprecated recursion uninitialized ];
@@ -53,6 +53,32 @@
$self;
}
+sub __import_from_file
+{
+ my $self = shift @_;
+ my $file = shift @_;
+ my $buf = "";
+ *$self->{buf} = \$buf;
+ *$self->{pos} = 0;
+ *$self->{lno} = 0;
+ return unless($file);
+
+ my $in;
+ my $inf = undef;
+ open($inf,$file);
+ binmode($inf,':raw');
+
+ $inf->seek(0,0);
+ while(!$inf->eof) {
+ $inf->read($in,512);
+ $buf.=$in;
+ }
+ $inf->close;
+ $self->seek(0,0);
+
+ $self;
+}
+
sub import_from_file {
my $self = shift @_;
my $file = shift @_;
@@ -454,6 +480,7 @@
*WRITE = \&write;
*CLOSE = \&close;
*SEEK = \&seek;
+*TELL = \&getpos;
sub string_ref
{
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/BaseFont.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/BaseFont.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/BaseFont.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -27,7 +27,7 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
#
-# $Id: BaseFont.pm,v 1.17 2005/06/17 19:44:03 fredo Exp $
+# $Id: BaseFont.pm,v 1.18 2005/10/19 19:06:27 fredo Exp $
#
#=======================================================================
package PDF::API2::Resource::BaseFont;
@@ -46,7 +46,7 @@
@ISA = qw( PDF::API2::Resource );
- ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.17 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/06/17 19:44:03 $
+ ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.18 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/10/19 19:06:27 $
}
no warnings qw[ deprecated recursion uninitialized ];
@@ -598,8 +598,15 @@
if(is_utf8($text)) {
$text=$self->strByUtf($text)
}
- foreach my $n (unpack('C*',$text)) {
+ my $lastglyph='';
+ foreach my $n (unpack('C*',$text))
+ {
$width+=$self->wxByEnc($n);
+ if($self->{-dokern} && ref($self->data->{kern}))
+ {
+ $width+=$self->data->{kern}->{$lastglyph.':'.$self->data->{e2n}->[$n]};
+ $lastglyph=$self->data->{e2n}->[$n];
+ }
}
$width/=1000;
return($width);
@@ -659,7 +666,8 @@
=cut
-sub textByStr {
+sub textByStr
+{
my ($self,$text)=@_;
my $newtext='';
if(is_utf8($text))
@@ -673,19 +681,64 @@
return($newtext);
}
-sub text {
- my ($self,$text,$size)=@_;
+sub textByStrKern
+{
+ my ($self,$text)=@_;
+ if($self->{-dokern} && ref($self->data->{kern}))
+ {
+ my $newtext=' ';
+ if(is_utf8($text))
+ {
+ $text=$self->strByUtf($text);
+ }
- my $newtext=$self->textByStr($text);
+ my $lastglyph='';
+ my $tBefore=0;
+ foreach my $n (unpack('C*',$text))
+ {
+ if(defined $self->data->{kern}->{$lastglyph.':'.$self->data->{e2n}->[$n]})
+ {
+ $newtext.=') ' if($tBefore);
+ $newtext.=sprintf('%i ',-($self->data->{kern}->{$lastglyph.':'.$self->data->{e2n}->[$n]}));
+ $tBefore=0;
+ }
+ $lastglyph=$self->data->{e2n}->[$n];
+ my $t=pack('C',$n);
+ $t=~s/\\/\\\\/go;
+ $t=~s/([\x00-\x1f])/sprintf('\%03lo',ord($1))/ge;
+ $t=~s/([\{\}\[\]\(\)])/\\$1/g;
+ $newtext.='(' if(!$tBefore);
+ $newtext.="$t";
+ $tBefore=1;
+ }
+ $newtext.=') ' if($tBefore);
+ return($newtext);
+ }
+ else
+ {
+ return('('.$self->textByStr($text).')');
+ }
+}
- if(defined $size)
- {
- return("($newtext) Tj");
- }
- else
- {
- return("($newtext)");
- }
+sub text
+{
+ my ($self,$text,$size)=@_;
+
+ my $newtext=$self->textByStr($text);
+
+ if(defined $size && $self->{-dokern})
+ {
+ $newtext=$self->textByStrKern($text);
+ return("[ $newtext ] TJ");
+ }
+ elsif(defined $size)
+ {
+ return("[ ($newtext) ] TJ");
+ }
+ else
+ {
+ return("($newtext)");
+ }
}
sub isvirtual { return(undef); }
@@ -703,6 +756,9 @@
=head1 HISTORY
$Log: BaseFont.pm,v $
+ Revision 1.18 2005/10/19 19:06:27 fredo
+ added handling of kerning
+
Revision 1.17 2005/06/17 19:44:03 fredo
fixed CPAN modulefile versioning (again)
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/CIDFont/TrueType/FontFile.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/CIDFont/TrueType/FontFile.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/CIDFont/TrueType/FontFile.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -27,7 +27,7 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
#
-# $Id: FontFile.pm,v 1.17 2005/09/12 16:52:59 fredo Exp $
+# $Id: FontFile.pm,v 1.18 2005/10/20 21:05:14 fredo Exp $
#
#=======================================================================
package PDF::API2::Resource::CIDFont::TrueType::FontFile;
@@ -42,14 +42,14 @@
use PDF::API2::Basic::PDF::Utils;
use PDF::API2::Basic::PDF::Dict;
use PDF::API2::Basic::TTF::Font;
-
+ use Data::Dumper;
use POSIX;
use vars qw( @ISA $VERSION $cmap );
@ISA = qw( PDF::API2::Basic::PDF::Dict );
- ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.17 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/09/12 16:52:59 $
+ ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.18 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/10/20 21:05:14 $
$cmap={};
}
no warnings qw[ recursion uninitialized ];
@@ -338,6 +338,54 @@
return($dict);
}
+sub read_kern_table
+{
+ my $font=shift @_;
+ my $upem=shift @_;
+ my $self=shift @_;
+ my $fh=$font->{' INFILE'};
+ my $data=undef;
+
+ return(undef) unless($font->{kern});
+
+ my $buf = undef;
+
+ seek($fh,$font->{kern}->{' OFFSET'}+2,0);
+ read($fh,$buf, 2);
+ my $num=unpack('n',$buf);
+ foreach my $n (1..$num)
+ {
+ read($fh, $buf, 6);
+ my ($ver, $len, $cov) = unpack('n3', $buf);
+ $len-=6;
+ my $fmt=$cov>>8;
+ if($fmt==0)
+ {
+ $data||={};
+ read($fh, $buf, 8);
+ my $nc = unpack('n', $buf);
+ foreach (1..$nc)
+ {
+ read($fh, $buf, 6);
+ my ($idx1,$idx2,$val)=unpack('nnn',$buf);
+ $val-=65536 if($val>32767);
+ $data->{"$idx1:$idx2"}=-int($val*1000/$upem);
+ $data->{$self->data->{g2n}->[$idx1].':'.$self->data->{g2n}->[$idx2]}=$data->{"$idx1:$idx2"};
+ }
+ }
+ elsif($fmt==2)
+ {
+ read($fh, $buf, $len);
+ }
+ else
+ {
+ read($fh, $buf, $len);
+ }
+ }
+ ##print Dumper($data);
+ return($data);
+}
+
sub readcffstructs
{
my $font=shift @_;
@@ -581,6 +629,10 @@
$data->{wx}->[$w]=int($font->{'hmtx'}->read->{'advance'}[$w]*1000/$data->{upem})
|| $data->{missingwidth};
}
+
+ $data->{kern}=read_kern_table($font,$data->{upem},$self);
+ delete $data->{kern} unless(defined $data->{kern});
+
return($self,$data);
}
@@ -588,7 +640,17 @@
sub data { return( $_[0]->{' data'} ); }
sub iscff { return( $_[0]->data->{iscff} ); }
-sub subsetByCId {
+sub haveKernPairs { return( $_[0]->data->{kern} ? 1 : 0 ); }
+
+sub kernPairCid
+{
+ my ($self, $i1, $i2) = @_;
+ return(0) if($i1==0 || $i2==0);
+ return($self->data->{kern}->{"$i1:$i2"} || 0);
+}
+
+sub subsetByCId
+{
my $self = shift @_;
my $g = shift @_;
$self->data->{subset}=1;
@@ -650,6 +712,9 @@
=head1 HISTORY
$Log: FontFile.pm,v $
+ Revision 1.18 2005/10/20 21:05:14 fredo
+ added handling of optional kerning
+
Revision 1.17 2005/09/12 16:52:59 fredo
added -isocmap option; fixed cmap handling for fallback entries
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/CIDFont/TrueType.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/CIDFont/TrueType.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/CIDFont/TrueType.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -27,7 +27,7 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
#
-# $Id: TrueType.pm,v 1.13 2005/09/12 16:53:23 fredo Exp $
+# $Id: TrueType.pm,v 1.15 2005/10/20 21:04:57 fredo Exp $
#
#=======================================================================
package PDF::API2::Resource::CIDFont::TrueType;
@@ -51,7 +51,7 @@
@ISA = qw( PDF::API2::Resource::CIDFont );
- ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.13 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/09/12 16:53:23 $
+ ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.15 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/10/20 21:04:57 $
}
no warnings qw[ deprecated recursion uninitialized ];
@@ -82,7 +82,7 @@
my ($ff,$data)=PDF::API2::Resource::CIDFont::TrueType::FontFile->new($pdf,$file, at opts);
$class = ref $class if ref $class;
- my $self=$class->SUPER::new($pdf,$data->{apiname}.pdfkey());
+ my $self=$class->SUPER::new($pdf,$data->{apiname}.pdfkey().'~'.time());
$pdf->new_obj($self) if(defined($pdf) && !$self->is_obj($pdf));
$self->{' data'}=$data;
@@ -95,7 +95,7 @@
$de->{'FontDescriptor'} = $des;
$de->{'Subtype'} = PDFName($self->iscff ? 'CIDFontType0' : 'CIDFontType2');
- $de->{'BaseFont'} = PDFName($self->fontname);
+ $de->{'BaseFont'} = PDFName(pdfkey().'+'.($self->fontname).'~'.time());
$de->{'DW'} = PDFNum($self->missingwidth);
$des->{$self->data->{iscff} ? 'FontFile3' : 'FontFile2'}=$ff;
@@ -113,6 +113,8 @@
$self->{' ff'} = $ff;
$pdf->new_obj($ff);
+ $self->{-dokern}=1 if($opts{-dokern});
+
return($self);
}
@@ -127,7 +129,8 @@
=cut
-sub new_api {
+sub new_api
+{
my ($class,$api, at opts)=@_;
my $obj=$class->new($api->{pdf}, at opts);
@@ -137,27 +140,45 @@
return($obj);
}
-sub wxByCId {
+sub wxByCId
+{
my $self=shift @_;
my $g=shift @_;
my $w;
- if(defined $self->fontobj->{'hmtx'}->read->{'advance'}[$g]) {
+ if(defined $self->fontobj->{'hmtx'}->read->{'advance'}[$g])
+ {
$w = int($self->fontobj->{'hmtx'}->read->{'advance'}[$g]*1000/$self->data->{upem});
- } else {
+ }
+ else
+ {
$w = $self->missingwidth;
}
return($w);
}
-sub subsetByCId {
+sub haveKernPairs
+{
my $self = shift @_;
+ return($self->fontfile->haveKernPairs(@_));
+}
+
+sub kernPairCid
+{
+ my $self = shift @_;
+ return($self->fontfile->kernPairCid(@_));
+}
+
+sub subsetByCId
+{
+ my $self = shift @_;
return if($self->iscff);
my $g = shift @_;
$self->fontfile->subsetByCId($g);
}
-sub subvec {
+sub subvec
+{
my $self = shift @_;
return(1) if($self->iscff);
my $g = shift @_;
@@ -166,7 +187,8 @@
sub glyphNum { return ( $_[0]->fontfile->glyphNum ); }
-sub outobjdeep {
+sub outobjdeep
+{
my ($self, $fh, $pdf, %opts) = @_;
return $self->SUPER::outobjdeep($fh, $pdf) if defined $opts{'passthru'};
@@ -177,16 +199,22 @@
$self->{' de'}->{'W'} = $wx;
my $ml;
- foreach my $w (0..(scalar @{$self->data->{g2u}} - 1 )) {
- if($self->subvec($w) && $notdefbefore==1) {
+ foreach my $w (0..(scalar @{$self->data->{g2u}} - 1 ))
+ {
+ if($self->subvec($w) && $notdefbefore==1)
+ {
$notdefbefore=0;
$ml=PDFArray();
$wx->add_elements(PDFNum($w),$ml);
$ml->add_elements(PDFNum($self->data->{wx}->[$w]));
- } elsif($self->subvec($w) && $notdefbefore==0) {
+ }
+ elsif($self->subvec($w) && $notdefbefore==0)
+ {
$notdefbefore=0;
$ml->add_elements(PDFNum($self->data->{wx}->[$w]));
- } else {
+ }
+ else
+ {
$notdefbefore=1;
}
# optimization for cjk
@@ -218,6 +246,12 @@
=head1 HISTORY
$Log: TrueType.pm,v $
+ Revision 1.15 2005/10/20 21:04:57 fredo
+ added handling of optional kerning
+
+ Revision 1.14 2005/10/01 22:30:16 fredo
+ fixed font-naming race condition for multiple document updates
+
Revision 1.13 2005/09/12 16:53:23 fredo
added -isocmap option
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/CIDFont.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/CIDFont.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/CIDFont.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -27,7 +27,7 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
#
-# $Id: CIDFont.pm,v 1.14 2005/06/17 19:44:03 fredo Exp $
+# $Id: CIDFont.pm,v 1.15 2005/10/20 21:05:05 fredo Exp $
#
#=======================================================================
package PDF::API2::Resource::CIDFont;
@@ -48,7 +48,7 @@
@ISA = qw( PDF::API2::Resource::BaseFont );
- ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.14 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/06/17 19:44:03 $
+ ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.15 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/10/20 21:05:05 $
}
no warnings qw[ deprecated recursion uninitialized ];
@@ -145,8 +145,17 @@
sub width_cid {
my ($self,$text)=@_;
my $width=0;
+ my $lastglyph=0;
foreach my $n (unpack('n*',$text)) {
$width+=$self->wxByCId($n);
+ if($self->{-dokern} && $self->haveKernPairs())
+ {
+ if($self->kernPairCid($lastglyph, $n))
+ {
+ $width-=$self->kernPairCid($lastglyph, $n);
+ }
+ }
+ $lastglyph=$n;
}
$width/=1000;
return($width);
@@ -210,12 +219,23 @@
return($self->text_cid($self->cidsByStr($text)));
}
+sub textByStrKern
+{
+ my ($self,$text,$size)=@_;
+ return($self->text_cid_kern($self->cidsByStr($text),$size));
+}
+
sub text
{
my ($self,$text,$size)=@_;
my $newtext=$self->textByStr($text);
- if(defined $size)
+ if(defined $size && $self->{-dokern})
{
+ $newtext=$self->textByStrKern($text,$size);
+ return($newtext);
+ }
+ elsif(defined $size)
+ {
return("$newtext Tj");
}
else
@@ -244,7 +264,62 @@
}
}
-sub encodeByName {
+sub text_cid_kern
+{
+ my ($self,$text,$size)=@_;
+ if(UNIVERSAL::can($self,'fontfile'))
+ {
+ foreach my $g (unpack('n*',$text))
+ {
+ $self->fontfile->subsetByCId($g);
+ }
+ }
+ if(defined $size && $self->{-dokern} && $self->haveKernPairs())
+ {
+ my $newtext=' ';
+ my $lastglyph=0;
+ my $tBefore=0;
+ foreach my $n (unpack('n*',$text))
+ {
+ if($self->kernPairCid($lastglyph, $n))
+ {
+ $newtext.='> ' if($tBefore);
+ $newtext.=sprintf('%i ',$self->kernPairCid($lastglyph, $n));
+ $tBefore=0;
+ }
+ $lastglyph=$n;
+ my $t=sprintf('%04X',$n);
+ $newtext.='<' if(!$tBefore);
+ $newtext.=$t;
+ $tBefore=1;
+ }
+ $newtext.='> ' if($tBefore);
+ return("[ $newtext ] TJ");
+ }
+ elsif(defined $size)
+ {
+ my $newtext=unpack('H*',$text);
+ return("<$newtext> Tj");
+ }
+ else
+ {
+ my $newtext=unpack('H*',$text);
+ return("<$newtext>");
+ }
+}
+
+sub kernPairCid
+{
+ return(0);
+}
+
+sub haveKernPairs
+{
+ return(0);
+}
+
+sub encodeByName
+{
my ($self,$enc) = @_;
return if($self->issymbol);
@@ -260,9 +335,14 @@
return($self);
}
+sub kernPairCid {
+ return(0);
+}
+
sub subsetByCId {
return(1);
}
+
sub subvec {
return(1);
}
@@ -295,6 +375,9 @@
=head1 HISTORY
$Log: CIDFont.pm,v $
+ Revision 1.15 2005/10/20 21:05:05 fredo
+ added handling of optional kerning
+
Revision 1.14 2005/06/17 19:44:03 fredo
fixed CPAN modulefile versioning (again)
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/BdFont.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/BdFont.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/BdFont.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -27,7 +27,7 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
#
-# $Id: BdFont.pm,v 1.6 2005/06/17 19:44:03 fredo Exp $
+# $Id: BdFont.pm,v 1.7 2005/10/01 22:41:07 fredo Exp $
#
#=======================================================================
package PDF::API2::Resource::Font::BdFont;
@@ -46,7 +46,7 @@
@ISA=qw(PDF::API2::Resource::Font);
- ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.6 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/06/17 19:44:03 $
+ ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.7 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/10/01 22:41:07 $
$BmpNum=0;
@@ -98,7 +98,7 @@
my %opts=@opts;
$class = ref $class if ref $class;
- $self = $class->SUPER::new($pdf, sprintf('%s+Bdf%02i',pdfkey(),++$BmpNum));
+ $self = $class->SUPER::new($pdf, sprintf('%s+Bdf%02i',pdfkey(),++$BmpNum).'~'.time());
$pdf->new_obj($self) unless($self->is_obj($pdf));
# adobe bitmap distribution font
@@ -244,7 +244,7 @@
$data->{bbox}{'.notdef'} = [0, 0, 0, 0];
}
- $data->{fontname}=pdfkey().'+'.time();
+ $data->{fontname}=pdfkey().pdfkey().'~'.time();
$data->{apiname}=$data->{fontname};
$data->{flags} = 34;
$data->{fontbbox} = [ split(/\s+/,$data->{FONTBOUNDINGBOX}) ];
@@ -301,6 +301,9 @@
=head1 HISTORY
$Log: BdFont.pm,v $
+ Revision 1.7 2005/10/01 22:41:07 fredo
+ fixed font-naming race condition for multiple document updates
+
Revision 1.6 2005/06/17 19:44:03 fredo
fixed CPAN modulefile versioning (again)
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/CoreFont/courier.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/CoreFont/courier.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/CoreFont/courier.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -27,7 +27,7 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
#
-# $Id: courier.pm,v 1.9 2005/09/12 16:56:21 fredo Exp $
+# $Id: courier.pm,v 1.11 2005/09/28 17:00:52 fredo Exp $
#
#=======================================================================
package PDF::API2::Resource::Font::CoreFont::courier;
@@ -308,322 +308,508 @@
'ydieresis', # C+FF, U+00FF
],
'wx' => {
- 'a' => 600,
- 'A' => 600,
- 'Aacute' => 600,
- 'aacute' => 600,
- 'abreve' => 600,
- 'Abreve' => 600,
- 'acircumflex' => 600,
- 'Acircumflex' => 600,
- 'acute' => 600,
- 'adieresis' => 600,
- 'Adieresis' => 600,
- 'AE' => 600,
- 'ae' => 600,
- 'agrave' => 600,
- 'Agrave' => 600,
- 'amacron' => 600,
- 'Amacron' => 600,
- 'ampersand' => 600,
- 'Aogonek' => 600,
- 'aogonek' => 600,
- 'aring' => 600,
- 'Aring' => 600,
- 'asciicircum' => 600,
- 'asciitilde' => 600,
- 'asterisk' => 600,
- 'at' => 600,
- 'atilde' => 600,
- 'Atilde' => 600,
- 'B' => 600,
- 'b' => 600,
- 'backslash' => 600,
- 'bar' => 600,
- 'braceleft' => 600,
- 'braceright' => 600,
- 'bracketleft' => 600,
- 'bracketright' => 600,
- 'breve' => 600,
- 'brokenbar' => 600,
- 'bullet' => 600,
- 'C' => 600,
- 'c' => 600,
- 'cacute' => 600,
- 'Cacute' => 600,
- 'caron' => 600,
- 'Ccaron' => 600,
- 'ccaron' => 600,
- 'ccedilla' => 600,
- 'Ccedilla' => 600,
- 'cedilla' => 600,
- 'cent' => 600,
- 'circumflex' => 600,
- 'colon' => 600,
- 'comma' => 600,
- 'commaaccent' => 600,
- 'copyright' => 600,
- 'currency' => 600,
- 'd' => 600,
- 'D' => 600,
- 'dagger' => 600,
- 'daggerdbl' => 600,
- 'dcaron' => 600,
- 'Dcaron' => 600,
- 'dcroat' => 600,
- 'Dcroat' => 600,
- 'degree' => 600,
- 'Delta' => 600,
- 'dieresis' => 600,
- 'divide' => 600,
- 'dollar' => 600,
- 'dotaccent' => 600,
- 'dotlessi' => 600,
- 'e' => 600,
- 'E' => 600,
- 'eacute' => 600,
- 'Eacute' => 600,
- 'ecaron' => 600,
- 'Ecaron' => 600,
- 'ecircumflex' => 600,
- 'Ecircumflex' => 600,
- 'edieresis' => 600,
- 'Edieresis' => 600,
- 'Edotaccent' => 600,
- 'edotaccent' => 600,
- 'egrave' => 600,
- 'Egrave' => 600,
- 'eight' => 600,
- 'ellipsis' => 600,
- 'Emacron' => 600,
- 'emacron' => 600,
- 'emdash' => 600,
- 'endash' => 600,
- 'eogonek' => 600,
- 'Eogonek' => 600,
- 'equal' => 600,
- 'Eth' => 600,
- 'eth' => 600,
- 'Euro' => 600,
- 'exclam' => 600,
- 'exclamdown' => 600,
- 'F' => 600,
- 'f' => 600,
- 'fi' => 600,
- 'five' => 600,
- 'fl' => 600,
- 'florin' => 600,
- 'four' => 600,
- 'fraction' => 600,
- 'G' => 600,
- 'g' => 600,
- 'Gbreve' => 600,
- 'gbreve' => 600,
- 'gcommaaccent' => 600,
- 'Gcommaaccent' => 600,
- 'germandbls' => 600,
- 'grave' => 600,
- 'greater' => 600,
- 'greaterequal' => 600,
- 'guillemotleft' => 600,
- 'guillemotright' => 600,
- 'guilsinglleft' => 600,
- 'guilsinglright' => 600,
- 'H' => 600,
- 'h' => 600,
- 'hungarumlaut' => 600,
- 'hyphen' => 600,
- 'I' => 600,
- 'i' => 600,
- 'Iacute' => 600,
- 'iacute' => 600,
- 'Icircumflex' => 600,
- 'icircumflex' => 600,
- 'idieresis' => 600,
- 'Idieresis' => 600,
- 'Idotaccent' => 600,
- 'igrave' => 600,
- 'Igrave' => 600,
- 'Imacron' => 600,
- 'imacron' => 600,
- 'Iogonek' => 600,
- 'iogonek' => 600,
- 'j' => 600,
- 'J' => 600,
- 'k' => 600,
- 'K' => 600,
- 'Kcommaaccent' => 600,
- 'kcommaaccent' => 600,
- 'L' => 600,
- 'l' => 600,
- 'lacute' => 600,
- 'Lacute' => 600,
- 'lcaron' => 600,
- 'Lcaron' => 600,
- 'lcommaaccent' => 600,
- 'Lcommaaccent' => 600,
- 'less' => 600,
- 'lessequal' => 600,
- 'logicalnot' => 600,
- 'lozenge' => 600,
- 'Lslash' => 600,
- 'lslash' => 600,
- 'M' => 600,
- 'm' => 600,
- 'macron' => 600,
- 'minus' => 600,
- 'mu' => 600,
- 'multiply' => 600,
- 'n' => 600,
- 'N' => 600,
- 'nacute' => 600,
- 'Nacute' => 600,
- 'ncaron' => 600,
- 'Ncaron' => 600,
- 'ncommaaccent' => 600,
- 'Ncommaaccent' => 600,
- 'nine' => 600,
- 'notequal' => 600,
- 'ntilde' => 600,
- 'Ntilde' => 600,
- 'numbersign' => 600,
- 'o' => 600,
- 'O' => 600,
- 'oacute' => 600,
- 'Oacute' => 600,
- 'Ocircumflex' => 600,
- 'ocircumflex' => 600,
- 'Odieresis' => 600,
- 'odieresis' => 600,
- 'oe' => 600,
- 'OE' => 600,
- 'ogonek' => 600,
- 'ograve' => 600,
- 'Ograve' => 600,
- 'ohungarumlaut' => 600,
- 'Ohungarumlaut' => 600,
- 'Omacron' => 600,
- 'omacron' => 600,
- 'one' => 600,
- 'onehalf' => 600,
- 'onequarter' => 600,
- 'onesuperior' => 600,
- 'ordfeminine' => 600,
- 'ordmasculine' => 600,
- 'Oslash' => 600,
- 'oslash' => 600,
- 'Otilde' => 600,
- 'otilde' => 600,
- 'P' => 600,
- 'p' => 600,
- 'paragraph' => 600,
- 'parenleft' => 600,
- 'parenright' => 600,
- 'partialdiff' => 600,
- 'percent' => 600,
- 'period' => 600,
- 'periodcentered' => 600,
- 'perthousand' => 600,
- 'plus' => 600,
- 'plusminus' => 600,
- 'Q' => 600,
- 'q' => 600,
- 'question' => 600,
- 'questiondown' => 600,
- 'quotedbl' => 600,
- 'quotedblbase' => 600,
- 'quotedblleft' => 600,
- 'quotedblright' => 600,
- 'quoteleft' => 600,
- 'quoteright' => 600,
- 'quotesinglbase' => 600,
- 'quotesingle' => 600,
- 'R' => 600,
- 'r' => 600,
- 'racute' => 600,
- 'Racute' => 600,
- 'radical' => 600,
- 'rcaron' => 600,
- 'Rcaron' => 600,
- 'rcommaaccent' => 600,
- 'Rcommaaccent' => 600,
- 'registered' => 600,
- 'ring' => 600,
- 'S' => 600,
- 's' => 600,
- 'Sacute' => 600,
- 'sacute' => 600,
- 'Scaron' => 600,
- 'scaron' => 600,
- 'Scedilla' => 600,
- 'scedilla' => 600,
- 'Scommaaccent' => 600,
- 'scommaaccent' => 600,
- 'section' => 600,
- 'semicolon' => 600,
- 'seven' => 600,
- 'six' => 600,
- 'slash' => 600,
- 'space' => 600,
- 'sterling' => 600,
- 'summation' => 600,
- 'T' => 600,
- 't' => 600,
- 'Tcaron' => 600,
- 'tcaron' => 600,
- 'tcommaaccent' => 600,
- 'Tcommaaccent' => 600,
- 'Thorn' => 600,
- 'thorn' => 600,
- 'three' => 600,
- 'threequarters' => 600,
- 'threesuperior' => 600,
- 'tilde' => 600,
- 'trademark' => 600,
- 'two' => 600,
- 'twosuperior' => 600,
- 'u' => 600,
- 'U' => 600,
- 'Uacute' => 600,
- 'uacute' => 600,
- 'ucircumflex' => 600,
- 'Ucircumflex' => 600,
- 'udieresis' => 600,
- 'Udieresis' => 600,
- 'Ugrave' => 600,
- 'ugrave' => 600,
- 'uhungarumlaut' => 600,
- 'Uhungarumlaut' => 600,
- 'umacron' => 600,
- 'Umacron' => 600,
- 'underscore' => 600,
- 'Uogonek' => 600,
- 'uogonek' => 600,
- 'Uring' => 600,
- 'uring' => 600,
- 'V' => 600,
- 'v' => 600,
- 'w' => 600,
- 'W' => 600,
- 'X' => 600,
- 'x' => 600,
- 'y' => 600,
- 'Y' => 600,
- 'yacute' => 600,
- 'Yacute' => 600,
- 'Ydieresis' => 600,
- 'ydieresis' => 600,
- 'yen' => 600,
- 'Z' => 600,
- 'z' => 600,
- 'zacute' => 600,
- 'Zacute' => 600,
- 'Zcaron' => 600,
- 'zcaron' => 600,
- 'Zdotaccent' => 600,
- 'zdotaccent' => 600,
- 'zero' => 600,
+ 'A' => '600', # U=0041
+ 'a' => '600', # U=0061
+ 'Aacute' => '600', # U=00C1
+ 'aacute' => '600', # U=00E1
+ 'Abreve' => '600', # U=0102
+ 'abreve' => '600', # U=0103
+ 'Acircumflex' => '600', # U=00C2
+ 'acircumflex' => '600', # U=00E2
+ 'acute' => '600', # U=00B4
+ 'Adieresis' => '600', # U=00C4
+ 'adieresis' => '600', # U=00E4
+ 'AE' => '600', # U=00C6
+ 'ae' => '600', # U=00E6
+ 'Agrave' => '600', # U=00C0
+ 'agrave' => '600', # U=00E0
+ 'Amacron' => '600', # U=0100
+ 'amacron' => '600', # U=0101
+ 'ampersand' => '600', # U=0026
+ 'Aogonek' => '600', # U=0104
+ 'aogonek' => '600', # U=0105
+ 'Aring' => '600', # U=00C5
+ 'aring' => '600', # U=00E5
+ 'asciicircum' => '600', # U=005E
+ 'asciitilde' => '600', # U=007E
+ 'asterisk' => '600', # U=002A
+ 'at' => '600', # U=0040
+ 'Atilde' => '600', # U=00C3
+ 'atilde' => '600', # U=00E3
+ 'B' => '600', # U=0042
+ 'b' => '600', # U=0062
+ 'backslash' => '600', # U=005C
+ 'bar' => '600', # U=007C
+ 'braceleft' => '600', # U=007B
+ 'braceright' => '600', # U=007D
+ 'bracketleft' => '600', # U=005B
+ 'bracketright' => '600', # U=005D
+ 'breve' => '600', # U=02D8
+ 'brokenbar' => '600', # U=00A6
+ 'bullet' => '600', # U=2022
+ 'C' => '600', # U=0043
+ 'c' => '600', # U=0063
+ 'Cacute' => '600', # U=0106
+ 'cacute' => '600', # U=0107
+ 'caron' => '600', # U=02C7
+ 'Ccaron' => '600', # U=010C
+ 'ccaron' => '600', # U=010D
+ 'Ccedilla' => '600', # U=00C7
+ 'ccedilla' => '600', # U=00E7
+ 'cedilla' => '600', # U=00B8
+ 'cent' => '600', # U=00A2
+ 'circumflex' => '600', # U=02C6
+ 'colon' => '600', # U=003A
+ 'comma' => '600', # U=002C
+ 'commaaccent' => '600', # U=F6C3
+ 'copyright' => '600', # U=00A9
+ 'currency' => '600', # U=00A4
+ 'D' => '600', # U=0044
+ 'd' => '600', # U=0064
+ 'dagger' => '600', # U=2020
+ 'daggerdbl' => '600', # U=2021
+ 'Dcaron' => '600', # U=010E
+ 'dcaron' => '600', # U=010F
+ 'Dcroat' => '600', # U=0110
+ 'dcroat' => '600', # U=0111
+ 'degree' => '600', # U=00B0
+ 'Delta' => '600', # U=0394
+ 'dieresis' => '600', # U=00A8
+ 'divide' => '600', # U=00F7
+ 'dollar' => '600', # U=0024
+ 'dotaccent' => '600', # U=02D9
+ 'dotlessi' => '600', # U=0131
+ 'E' => '600', # U=0045
+ 'e' => '600', # U=0065
+ 'Eacute' => '600', # U=00C9
+ 'eacute' => '600', # U=00E9
+ 'Ecaron' => '600', # U=011A
+ 'ecaron' => '600', # U=011B
+ 'Ecircumflex' => '600', # U=00CA
+ 'ecircumflex' => '600', # U=00EA
+ 'Edieresis' => '600', # U=00CB
+ 'edieresis' => '600', # U=00EB
+ 'Edotaccent' => '600', # U=0116
+ 'edotaccent' => '600', # U=0117
+ 'Egrave' => '600', # U=00C8
+ 'egrave' => '600', # U=00E8
+ 'eight' => '600', # U=0038
+ 'ellipsis' => '600', # U=2026
+ 'Emacron' => '600', # U=0112
+ 'emacron' => '600', # U=0113
+ 'emdash' => '600', # U=2014
+ 'endash' => '600', # U=2013
+ 'Eogonek' => '600', # U=0118
+ 'eogonek' => '600', # U=0119
+ 'equal' => '600', # U=003D
+ 'Eth' => '600', # U=00D0
+ 'eth' => '600', # U=00F0
+ 'Euro' => '600', # U=20AC
+ 'exclam' => '600', # U=0021
+ 'exclamdown' => '600', # U=00A1
+ 'F' => '600', # U=0046
+ 'f' => '600', # U=0066
+ 'fi' => '600', # U=FB01
+ 'five' => '600', # U=0035
+ 'fl' => '600', # U=FB02
+ 'florin' => '600', # U=0192
+ 'four' => '600', # U=0034
+ 'fraction' => '600', # U=2044
+ 'G' => '600', # U=0047
+ 'g' => '600', # U=0067
+ 'Gbreve' => '600', # U=011E
+ 'gbreve' => '600', # U=011F
+ 'Gcommaaccent' => '600', # U=0122
+ 'gcommaaccent' => '600', # U=0123
+ 'germandbls' => '600', # U=00DF
+ 'grave' => '600', # U=0060
+ 'greater' => '600', # U=003E
+ 'greaterequal' => '600', # U=2265
+ 'guillemotleft' => '600', # U=00AB
+ 'guillemotright' => '600', # U=00BB
+ 'guilsinglleft' => '600', # U=2039
+ 'guilsinglright' => '600', # U=203A
+ 'H' => '600', # U=0048
+ 'h' => '600', # U=0068
+ 'hungarumlaut' => '600', # U=02DD
+ 'hyphen' => '600', # U=002D
+ 'I' => '600', # U=0049
+ 'i' => '600', # U=0069
+ 'Iacute' => '600', # U=00CD
+ 'iacute' => '600', # U=00ED
+ 'Icircumflex' => '600', # U=00CE
+ 'icircumflex' => '600', # U=00EE
+ 'Idieresis' => '600', # U=00CF
+ 'idieresis' => '600', # U=00EF
+ 'Idotaccent' => '600', # U=0130
+ 'Igrave' => '600', # U=00CC
+ 'igrave' => '600', # U=00EC
+ 'Imacron' => '600', # U=012A
+ 'imacron' => '600', # U=012B
+ 'Iogonek' => '600', # U=012E
+ 'iogonek' => '600', # U=012F
+ 'J' => '600', # U=004A
+ 'j' => '600', # U=006A
+ 'K' => '600', # U=004B
+ 'k' => '600', # U=006B
+ 'Kcommaaccent' => '600', # U=0136
+ 'kcommaaccent' => '600', # U=0137
+ 'L' => '600', # U=004C
+ 'l' => '600', # U=006C
+ 'Lacute' => '600', # U=0139
+ 'lacute' => '600', # U=013A
+ 'Lcaron' => '600', # U=013D
+ 'lcaron' => '600', # U=013E
+ 'Lcommaaccent' => '600', # U=013B
+ 'lcommaaccent' => '600', # U=013C
+ 'less' => '600', # U=003C
+ 'lessequal' => '600', # U=2264
+ 'logicalnot' => '600', # U=00AC
+ 'lozenge' => '600', # U=25CA
+ 'Lslash' => '600', # U=0141
+ 'lslash' => '600', # U=0142
+ 'M' => '600', # U=004D
+ 'm' => '600', # U=006D
+ 'macron' => '600', # U=00AF
+ 'minus' => '600', # U=2212
+ 'mu' => '600', # U=00B5
+ 'multiply' => '600', # U=00D7
+ 'N' => '600', # U=004E
+ 'n' => '600', # U=006E
+ 'Nacute' => '600', # U=0143
+ 'nacute' => '600', # U=0144
+ 'Ncaron' => '600', # U=0147
+ 'ncaron' => '600', # U=0148
+ 'Ncommaaccent' => '600', # U=0145
+ 'ncommaaccent' => '600', # U=0146
+ 'nine' => '600', # U=0039
+ 'notequal' => '600', # U=2260
+ 'Ntilde' => '600', # U=00D1
+ 'ntilde' => '600', # U=00F1
+ 'numbersign' => '600', # U=0023
+ 'O' => '600', # U=004F
+ 'o' => '600', # U=006F
+ 'Oacute' => '600', # U=00D3
+ 'oacute' => '600', # U=00F3
+ 'Ocircumflex' => '600', # U=00D4
+ 'ocircumflex' => '600', # U=00F4
+ 'Odieresis' => '600', # U=00D6
+ 'odieresis' => '600', # U=00F6
+ 'OE' => '600', # U=0152
+ 'oe' => '600', # U=0153
+ 'ogonek' => '600', # U=02DB
+ 'Ograve' => '600', # U=00D2
+ 'ograve' => '600', # U=00F2
+ 'Ohungarumlaut' => '600', # U=0150
+ 'ohungarumlaut' => '600', # U=0151
+ 'Omacron' => '600', # U=014C
+ 'omacron' => '600', # U=014D
+ 'one' => '600', # U=0031
+ 'onehalf' => '600', # U=00BD
+ 'onequarter' => '600', # U=00BC
+ 'onesuperior' => '600', # U=00B9
+ 'ordfeminine' => '600', # U=00AA
+ 'ordmasculine' => '600', # U=00BA
+ 'Oslash' => '600', # U=00D8
+ 'oslash' => '600', # U=00F8
+ 'Otilde' => '600', # U=00D5
+ 'otilde' => '600', # U=00F5
+ 'P' => '600', # U=0050
+ 'p' => '600', # U=0070
+ 'paragraph' => '600', # U=00B6
+ 'parenleft' => '600', # U=0028
+ 'parenright' => '600', # U=0029
+ 'partialdiff' => '600', # U=2202
+ 'percent' => '600', # U=0025
+ 'period' => '600', # U=002E
+ 'periodcentered' => '600', # U=00B7
+ 'perthousand' => '600', # U=2030
+ 'plus' => '600', # U=002B
+ 'plusminus' => '600', # U=00B1
+ 'Q' => '600', # U=0051
+ 'q' => '600', # U=0071
+ 'question' => '600', # U=003F
+ 'questiondown' => '600', # U=00BF
+ 'quotedbl' => '600', # U=0022
+ 'quotedblbase' => '600', # U=201E
+ 'quotedblleft' => '600', # U=201C
+ 'quotedblright' => '600', # U=201D
+ 'quoteleft' => '600', # U=2018
+ 'quoteright' => '600', # U=2019
+ 'quotesinglbase' => '600', # U=201A
+ 'quotesingle' => '600', # U=0027
+ 'R' => '600', # U=0052
+ 'r' => '600', # U=0072
+ 'Racute' => '600', # U=0154
+ 'racute' => '600', # U=0155
+ 'radical' => '600', # U=221A
+ 'Rcaron' => '600', # U=0158
+ 'rcaron' => '600', # U=0159
+ 'Rcommaaccent' => '600', # U=0156
+ 'rcommaaccent' => '600', # U=0157
+ 'registered' => '600', # U=00AE
+ 'ring' => '600', # U=02DA
+ 'S' => '600', # U=0053
+ 's' => '600', # U=0073
+ 'Sacute' => '600', # U=015A
+ 'sacute' => '600', # U=015B
+ 'Scaron' => '600', # U=0160
+ 'scaron' => '600', # U=0161
+ 'Scedilla' => '600', # U=015E
+ 'scedilla' => '600', # U=015F
+ 'Scommaaccent' => '600', # U=0218
+ 'scommaaccent' => '600', # U=0219
+ 'section' => '600', # U=00A7
+ 'semicolon' => '600', # U=003B
+ 'seven' => '600', # U=0037
+ 'six' => '600', # U=0036
+ 'slash' => '600', # U=002F
+ 'space' => '600', # U=0020
+ 'sterling' => '600', # U=00A3
+ 'summation' => '600', # U=2211
+ 'T' => '600', # U=0054
+ 't' => '600', # U=0074
+ 'Tcaron' => '600', # U=0164
+ 'tcaron' => '600', # U=0165
+ 'Tcommaaccent' => '600', # U=021A
+ 'tcommaaccent' => '600', # U=021B
+ 'Thorn' => '600', # U=00DE
+ 'thorn' => '600', # U=00FE
+ 'three' => '600', # U=0033
+ 'threequarters' => '600', # U=00BE
+ 'threesuperior' => '600', # U=00B3
+ 'tilde' => '600', # U=02DC
+ 'trademark' => '600', # U=2122
+ 'two' => '600', # U=0032
+ 'twosuperior' => '600', # U=00B2
+ 'U' => '600', # U=0055
+ 'u' => '600', # U=0075
+ 'Uacute' => '600', # U=00DA
+ 'uacute' => '600', # U=00FA
+ 'Ucircumflex' => '600', # U=00DB
+ 'ucircumflex' => '600', # U=00FB
+ 'Udieresis' => '600', # U=00DC
+ 'udieresis' => '600', # U=00FC
+ 'Ugrave' => '600', # U=00D9
+ 'ugrave' => '600', # U=00F9
+ 'Uhungarumlaut' => '600', # U=0170
+ 'uhungarumlaut' => '600', # U=0171
+ 'Umacron' => '600', # U=016A
+ 'umacron' => '600', # U=016B
+ 'underscore' => '600', # U=005F
+ 'Uogonek' => '600', # U=0172
+ 'uogonek' => '600', # U=0173
+ 'Uring' => '600', # U=016E
+ 'uring' => '600', # U=016F
+ 'V' => '600', # U=0056
+ 'v' => '600', # U=0076
+ 'W' => '600', # U=0057
+ 'w' => '600', # U=0077
+ 'X' => '600', # U=0058
+ 'x' => '600', # U=0078
+ 'Y' => '600', # U=0059
+ 'y' => '600', # U=0079
+ 'Yacute' => '600', # U=00DD
+ 'yacute' => '600', # U=00FD
+ 'Ydieresis' => '600', # U=0178
+ 'ydieresis' => '600', # U=00FF
+ 'yen' => '600', # U=00A5
+ 'Z' => '600', # U=005A
+ 'z' => '600', # U=007A
+ 'Zacute' => '600', # U=0179
+ 'zacute' => '600', # U=017A
+ 'Zcaron' => '600', # U=017D
+ 'zcaron' => '600', # U=017E
+ 'Zdotaccent' => '600', # U=017B
+ 'zdotaccent' => '600', # U=017C
+ 'zero' => '600', # U=0030
},
+ 'comps' => {
+ 'Abreve' => [ 'A', '0', '0', 'breve', '0', '130' ], # U=0102
+ 'abreve' => [ 'A', '0', '0', 'breve', '0', '0' ], # U=0103
+ 'Acaron' => [ 'A', '0', '0', 'caron', '0', '130' ], # U=01CD
+ 'acaron' => [ 'A', '0', '0', 'caron', '0', '0' ], # U=01CE
+ 'Amacron' => [ 'A', '0', '0', 'macron', '0', '130' ], # U=0100
+ 'amacron' => [ 'A', '0', '0', 'macron', '0', '0' ], # U=0101
+ 'Aogonek' => [ 'A', '0', '0', 'ogonek', '0', '0' ], # U=0104
+ 'aogonek' => [ 'A', '0', '0', 'ogonek', '0', '0' ], # U=0105
+ 'Bdotaccent' => [ 'B', '0', '0', 'dotaccent', '0', '130' ], # U=1E02
+ 'bdotaccent' => [ 'B', '0', '0', 'dotaccent', '0', '0' ], # U=1E03
+ 'Cacute' => [ 'C', '0', '0', 'acute', '0', '130' ], # U=0106
+ 'cacute' => [ 'C', '0', '0', 'acute', '0', '0' ], # U=0107
+ 'Ccaron' => [ 'C', '0', '0', 'caron', '0', '130' ], # U=010C
+ 'ccaron' => [ 'C', '0', '0', 'caron', '0', '0' ], # U=010D
+ 'Ccircumflex' => [ 'C', '0', '0', 'circumflex', '0', '130' ], # U=0108
+ 'ccircumflex' => [ 'C', '0', '0', 'circumflex', '0', '0' ], # U=0109
+ 'Cdotaccent' => [ 'C', '0', '0', 'dotaccent', '0', '130' ], # U=010A
+ 'cdotaccent' => [ 'C', '0', '0', 'dotaccent', '0', '0' ], # U=010B
+ 'Dcaron' => [ 'D', '0', '0', 'caron', '0', '130' ], # U=010E
+ 'dcaron' => [ 'D', '0', '0', 'caron', '0', '0' ], # U=010F
+ 'Dcedilla' => [ 'D', '0', '0', 'cedilla', '0', '130' ], # U=1E10
+ 'dcedilla' => [ 'D', '0', '0', 'cedilla', '0', '0' ], # U=1E11
+ 'Ddotaccent' => [ 'D', '0', '0', 'dotaccent', '0', '130' ], # U=1E0A
+ 'ddotaccent' => [ 'D', '0', '0', 'dotaccent', '0', '0' ], # U=1E0B
+ 'Ebreve' => [ 'E', '0', '0', 'breve', '0', '130' ], # U=0114
+ 'ebreve' => [ 'E', '0', '0', 'breve', '0', '0' ], # U=0115
+ 'Ecaron' => [ 'E', '0', '0', 'caron', '0', '130' ], # U=011A
+ 'ecaron' => [ 'E', '0', '0', 'caron', '0', '0' ], # U=011B
+ 'Edotaccent' => [ 'E', '0', '0', 'dotaccent', '0', '130' ], # U=0116
+ 'edotaccent' => [ 'E', '0', '0', 'dotaccent', '0', '0' ], # U=0117
+ 'Emacron' => [ 'E', '0', '0', 'macron', '0', '130' ], # U=0112
+ 'emacron' => [ 'E', '0', '0', 'macron', '0', '0' ], # U=0113
+ 'Eogonek' => [ 'E', '0', '0', 'ogonek', '0', '0' ], # U=0118
+ 'eogonek' => [ 'E', '0', '0', 'ogonek', '0', '0' ], # U=0119
+ 'Etilde' => [ 'E', '0', '0', 'tilde', '0', '130' ], # U=1EBC
+ 'etilde' => [ 'E', '0', '0', 'tilde', '0', '0' ], # U=1EBD
+ 'Fdotaccent' => [ 'F', '0', '0', 'dotaccent', '0', '130' ], # U=1E1E
+ 'fdotaccent' => [ 'F', '0', '0', 'dotaccent', '0', '0' ], # U=1E1F
+ 'Gacute' => [ 'G', '0', '0', 'acute', '0', '130' ], # U=01F4
+ 'gacute' => [ 'G', '0', '0', 'acute', '0', '0' ], # U=01F5
+ 'Gbreve' => [ 'G', '0', '0', 'breve', '0', '130' ], # U=011E
+ 'gbreve' => [ 'G', '0', '0', 'breve', '0', '0' ], # U=011F
+ 'Gcaron' => [ 'G', '0', '0', 'caron', '0', '136' ], # U=01E6
+ 'gcaron' => [ 'g', '0', '0', 'caron', '-30', '0' ], # U=01E7
+ 'Gcedilla' => [ 'G', '0', '0', 'cedilla', '0', '130' ], # U=0122
+ 'gcedilla' => [ 'G', '0', '0', 'cedilla', '0', '0' ], # U=0123
+ 'Gcircumflex' => [ 'G', '0', '0', 'circumflex', '0', '130' ], # U=011C
+ 'gcircumflex' => [ 'G', '0', '0', 'circumflex', '0', '0' ], # U=011D
+ 'Gdotaccent' => [ 'G', '0', '0', 'dotaccent', '0', '130' ], # U=0120
+ 'gdotaccent' => [ 'G', '0', '0', 'dotaccent', '0', '0' ], # U=0121
+ 'Gmacron' => [ 'G', '0', '0', 'macron', '0', '130' ], # U=1E20
+ 'gmacron' => [ 'G', '0', '0', 'macron', '0', '0' ], # U=1E21
+ 'Hcedilla' => [ 'H', '0', '0', 'cedilla', '0', '130' ], # U=1E28
+ 'hcedilla' => [ 'H', '0', '0', 'cedilla', '0', '0' ], # U=1E29
+ 'Hcircumflex' => [ 'H', '0', '0', 'circumflex', '0', '130' ], # U=0124
+ 'hcircumflex' => [ 'H', '0', '0', 'circumflex', '0', '0' ], # U=0125
+ 'Hdieresis' => [ 'H', '0', '0', 'dieresis', '0', '130' ], # U=1E26
+ 'hdieresis' => [ 'H', '0', '0', 'dieresis', '0', '0' ], # U=1E27
+ 'Hdotaccent' => [ 'H', '0', '0', 'dotaccent', '0', '130' ], # U=1E22
+ 'hdotaccent' => [ 'H', '0', '0', 'dotaccent', '0', '0' ], # U=1E23
+ 'Ibreve' => [ 'I', '0', '0', 'breve', '0', '130' ], # U=012C
+ 'ibreve' => [ 'I', '0', '0', 'breve', '0', '0' ], # U=012D
+ 'Icaron' => [ 'I', '0', '0', 'caron', '0', '130' ], # U=01CF
+ 'icaron' => [ 'I', '0', '0', 'caron', '0', '0' ], # U=01D0
+ 'Idotaccent' => [ 'I', '0', '0', 'dotaccent', '0', '130' ], # U=0130
+ 'Imacron' => [ 'I', '0', '0', 'macron', '0', '130' ], # U=012A
+ 'imacron' => [ 'I', '0', '0', 'macron', '0', '0' ], # U=012B
+ 'Iogonek' => [ 'I', '0', '0', 'ogonek', '0', '0' ], # U=012E
+ 'iogonek' => [ 'I', '0', '0', 'ogonek', '0', '0' ], # U=012F
+ 'Itilde' => [ 'I', '0', '0', 'tilde', '0', '130' ], # U=0128
+ 'itilde' => [ 'I', '0', '0', 'tilde', '0', '0' ], # U=0129
+ 'Jcircumflex' => [ 'J', '0', '0', 'circumflex', '0', '130' ], # U=0134
+ 'jcircumflex' => [ 'J', '0', '0', 'circumflex', '0', '0' ], # U=0135
+ 'Kacute' => [ 'K', '0', '0', 'acute', '0', '130' ], # U=1E30
+ 'kacute' => [ 'K', '0', '0', 'acute', '0', '0' ], # U=1E31
+ 'Kcaron' => [ 'K', '0', '0', 'caron', '0', '130' ], # U=01E8
+ 'kcaron' => [ 'K', '0', '0', 'caron', '0', '0' ], # U=01E9
+ 'Kcedilla' => [ 'K', '0', '0', 'cedilla', '0', '130' ], # U=0136
+ 'kcedilla' => [ 'K', '0', '0', 'cedilla', '0', '0' ], # U=0137
+ 'Lacute' => [ 'L', '0', '0', 'acute', '0', '130' ], # U=0139
+ 'lacute' => [ 'L', '0', '0', 'acute', '0', '0' ], # U=013A
+ 'Lcaron' => [ 'L', '0', '0', 'caron', '0', '130' ], # U=013D
+ 'lcaron' => [ 'L', '0', '0', 'caron', '0', '0' ], # U=013E
+ 'Lcedilla' => [ 'L', '0', '0', 'cedilla', '0', '130' ], # U=013B
+ 'lcedilla' => [ 'L', '0', '0', 'cedilla', '0', '0' ], # U=013C
+ 'Ldotaccent' => [ 'L', '0', '0', 'dotaccent', '0', '130' ], # U=013F
+ 'ldotaccent' => [ 'L', '0', '0', 'dotaccent', '0', '0' ], # U=0140
+ 'Macute' => [ 'M', '0', '0', 'acute', '0', '130' ], # U=1E3E
+ 'macute' => [ 'M', '0', '0', 'acute', '0', '0' ], # U=1E3F
+ 'Mdotaccent' => [ 'M', '0', '0', 'dotaccent', '0', '130' ], # U=1E40
+ 'mdotaccent' => [ 'M', '0', '0', 'dotaccent', '0', '0' ], # U=1E41
+ 'Nacute' => [ 'N', '0', '0', 'acute', '0', '130' ], # U=0143
+ 'nacute' => [ 'N', '0', '0', 'acute', '0', '0' ], # U=0144
+ 'Ncaron' => [ 'N', '0', '0', 'caron', '0', '130' ], # U=0147
+ 'ncaron' => [ 'N', '0', '0', 'caron', '0', '0' ], # U=0148
+ 'Ncedilla' => [ 'N', '0', '0', 'cedilla', '0', '130' ], # U=0145
+ 'ncedilla' => [ 'N', '0', '0', 'cedilla', '0', '0' ], # U=0146
+ 'Ndotaccent' => [ 'N', '0', '0', 'dotaccent', '0', '130' ], # U=1E44
+ 'ndotaccent' => [ 'N', '0', '0', 'dotaccent', '0', '0' ], # U=1E45
+ 'Obreve' => [ 'O', '0', '0', 'breve', '0', '130' ], # U=014E
+ 'obreve' => [ 'O', '0', '0', 'breve', '0', '0' ], # U=014F
+ 'Ocaron' => [ 'O', '0', '0', 'caron', '0', '130' ], # U=01D1
+ 'ocaron' => [ 'O', '0', '0', 'caron', '0', '0' ], # U=01D2
+ 'Ohungarumlaut' => [ 'O', '0', '0', 'hungarumlaut', '0', '130' ], # U=0150
+ 'ohungarumlaut' => [ 'O', '0', '0', 'hungarumlaut', '0', '0' ], # U=0151
+ 'Omacron' => [ 'O', '0', '0', 'macron', '0', '130' ], # U=014C
+ 'omacron' => [ 'O', '0', '0', 'macron', '0', '0' ], # U=014D
+ 'Oogonek' => [ 'O', '0', '0', 'ogonek', '0', '0' ], # U=01EA
+ 'oogonek' => [ 'O', '0', '0', 'ogonek', '0', '0' ], # U=01EB
+ 'Pacute' => [ 'P', '0', '0', 'acute', '0', '130' ], # U=1E54
+ 'pacute' => [ 'P', '0', '0', 'acute', '0', '0' ], # U=1E55
+ 'Pdotaccent' => [ 'P', '0', '0', 'dotaccent', '0', '130' ], # U=1E56
+ 'pdotaccent' => [ 'P', '0', '0', 'dotaccent', '0', '0' ], # U=1E57
+ 'Racute' => [ 'R', '0', '0', 'acute', '0', '130' ], # U=0154
+ 'racute' => [ 'R', '0', '0', 'acute', '0', '0' ], # U=0155
+ 'Rcaron' => [ 'R', '0', '0', 'caron', '0', '130' ], # U=0158
+ 'rcaron' => [ 'R', '0', '0', 'caron', '0', '0' ], # U=0159
+ 'Rcedilla' => [ 'R', '0', '0', 'cedilla', '0', '130' ], # U=0156
+ 'rcedilla' => [ 'R', '0', '0', 'cedilla', '0', '0' ], # U=0157
+ 'Rdotaccent' => [ 'R', '0', '0', 'dotaccent', '0', '130' ], # U=1E58
+ 'rdotaccent' => [ 'R', '0', '0', 'dotaccent', '0', '0' ], # U=1E59
+ 'Sacute' => [ 'S', '0', '0', 'acute', '0', '130' ], # U=015A
+ 'sacute' => [ 'S', '0', '0', 'acute', '0', '0' ], # U=015B
+ 'Scaron' => [ 'S', '0', '0', 'caron', '30', '136' ], # U=0160
+ 'scaron' => [ 's', '0', '0', 'caron', '0', '0' ], # U=0161
+ 'Scedilla' => [ 'S', '0', '0', 'cedilla', '0', '130' ], # U=015E
+ 'scedilla' => [ 'S', '0', '0', 'cedilla', '0', '0' ], # U=015F
+ 'Scircumflex' => [ 'S', '0', '0', 'circumflex', '0', '130' ], # U=015C
+ 'scircumflex' => [ 'S', '0', '0', 'circumflex', '0', '0' ], # U=015D
+ 'Sdotaccent' => [ 'S', '0', '0', 'dotaccent', '0', '130' ], # U=1E60
+ 'sdotaccent' => [ 'S', '0', '0', 'dotaccent', '0', '0' ], # U=1E61
+ 'Tcaron' => [ 'T', '0', '0', 'caron', '0', '130' ], # U=0164
+ 'tcaron' => [ 'T', '0', '0', 'caron', '0', '0' ], # U=0165
+ 'Tcedilla' => [ 'T', '0', '0', 'cedilla', '0', '130' ], # U=0162
+ 'tcedilla' => [ 'T', '0', '0', 'cedilla', '0', '0' ], # U=0163
+ 'Tdotaccent' => [ 'T', '0', '0', 'dotaccent', '0', '130' ], # U=1E6A
+ 'tdotaccent' => [ 'T', '0', '0', 'dotaccent', '0', '0' ], # U=1E6B
+ 'Ubreve' => [ 'U', '0', '0', 'breve', '0', '130' ], # U=016C
+ 'ubreve' => [ 'U', '0', '0', 'breve', '0', '0' ], # U=016D
+ 'Ucaron' => [ 'U', '0', '0', 'caron', '0', '130' ], # U=01D3
+ 'ucaron' => [ 'U', '0', '0', 'caron', '0', '0' ], # U=01D4
+ 'Uhungarumlaut' => [ 'U', '0', '0', 'hungarumlaut', '0', '130' ], # U=0170
+ 'uhungarumlaut' => [ 'U', '0', '0', 'hungarumlaut', '0', '0' ], # U=0171
+ 'Umacron' => [ 'U', '0', '0', 'macron', '0', '130' ], # U=016A
+ 'umacron' => [ 'U', '0', '0', 'macron', '0', '0' ], # U=016B
+ 'Uogonek' => [ 'U', '0', '0', 'ogonek', '0', '0' ], # U=0172
+ 'uogonek' => [ 'U', '0', '0', 'ogonek', '0', '0' ], # U=0173
+ 'Uring' => [ 'U', '0', '0', 'ring', '0', '130' ], # U=016E
+ 'uring' => [ 'U', '0', '0', 'ring', '0', '0' ], # U=016F
+ 'Utilde' => [ 'U', '0', '0', 'tilde', '0', '130' ], # U=0168
+ 'utilde' => [ 'U', '0', '0', 'tilde', '0', '0' ], # U=0169
+ 'Vtilde' => [ 'V', '0', '0', 'tilde', '0', '130' ], # U=1E7C
+ 'vtilde' => [ 'V', '0', '0', 'tilde', '0', '0' ], # U=1E7D
+ 'Wacute' => [ 'W', '0', '0', 'acute', '0', '130' ], # U=1E82
+ 'wacute' => [ 'W', '0', '0', 'acute', '0', '0' ], # U=1E83
+ 'Wcircumflex' => [ 'W', '0', '0', 'circumflex', '0', '130' ], # U=0174
+ 'wcircumflex' => [ 'W', '0', '0', 'circumflex', '0', '0' ], # U=0175
+ 'Wdieresis' => [ 'W', '0', '0', 'dieresis', '0', '130' ], # U=1E84
+ 'wdieresis' => [ 'W', '0', '0', 'dieresis', '0', '0' ], # U=1E85
+ 'Wdotaccent' => [ 'W', '0', '0', 'dotaccent', '0', '130' ], # U=1E86
+ 'wdotaccent' => [ 'W', '0', '0', 'dotaccent', '0', '0' ], # U=1E87
+ 'Wgrave' => [ 'W', '0', '0', 'grave', '0', '130' ], # U=1E80
+ 'wgrave' => [ 'W', '0', '0', 'grave', '0', '0' ], # U=1E81
+ 'Xdieresis' => [ 'X', '0', '0', 'dieresis', '0', '130' ], # U=1E8C
+ 'xdieresis' => [ 'X', '0', '0', 'dieresis', '0', '0' ], # U=1E8D
+ 'Xdotaccent' => [ 'X', '0', '0', 'dotaccent', '0', '130' ], # U=1E8A
+ 'xdotaccent' => [ 'X', '0', '0', 'dotaccent', '0', '0' ], # U=1E8B
+ 'Ycircumflex' => [ 'Y', '0', '0', 'circumflex', '0', '130' ], # U=0176
+ 'ycircumflex' => [ 'Y', '0', '0', 'circumflex', '0', '0' ], # U=0177
+ 'Ydieresis' => [ 'Y', '0', '0', 'dieresis', '0', '136' ], # U=0178
+ 'Ydotaccent' => [ 'Y', '0', '0', 'dotaccent', '0', '130' ], # U=1E8E
+ 'ydotaccent' => [ 'Y', '0', '0', 'dotaccent', '0', '0' ], # U=1E8F
+ 'Ygrave' => [ 'Y', '0', '0', 'grave', '0', '130' ], # U=1EF2
+ 'ygrave' => [ 'Y', '0', '0', 'grave', '0', '0' ], # U=1EF3
+ 'Ytilde' => [ 'Y', '0', '0', 'tilde', '0', '130' ], # U=1EF8
+ 'ytilde' => [ 'Y', '0', '0', 'tilde', '0', '0' ], # U=1EF9
+ 'Zacute' => [ 'Z', '0', '0', 'acute', '0', '130' ], # U=0179
+ 'zacute' => [ 'Z', '0', '0', 'acute', '0', '0' ], # U=017A
+ 'Zcaron' => [ 'Z', '0', '0', 'caron', '0', '136' ], # U=017D
+ 'zcaron' => [ 'z', '0', '0', 'caron', '10', '0' ], # U=017E
+ 'Zcircumflex' => [ 'Z', '0', '0', 'circumflex', '0', '130' ], # U=1E90
+ 'zcircumflex' => [ 'Z', '0', '0', 'circumflex', '0', '0' ], # U=1E91
+ 'Zdotaccent' => [ 'Z', '0', '0', 'dotaccent', '0', '130' ], # U=017B
+ 'zdotaccent' => [ 'Z', '0', '0', 'dotaccent', '0', '0' ], # U=017C
+ },
};
@@ -636,6 +822,12 @@
=head1 HISTORY
$Log: courier.pm,v $
+ Revision 1.11 2005/09/28 17:00:52 fredo
+ added composites
+
+ Revision 1.10 2005/09/26 19:28:16 fredo
+ no message
+
Revision 1.9 2005/09/12 16:56:21 fredo
applied mod_perl patch by Paul Schilling <pfschill at sbcglobal.net>
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/CoreFont.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/CoreFont.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/CoreFont.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -38,7 +38,7 @@
# FREE SOFTWARE FOUNDATION, INC., 59 TEMPLE PLACE - SUITE 330,
# BOSTON, MA 02111-1307, USA.
#
-# $Id: CoreFont.pm,v 1.14 2005/09/12 16:56:20 fredo Exp $
+# $Id: CoreFont.pm,v 1.17 2005/10/19 19:15:12 fredo Exp $
#
#=======================================================================
package PDF::API2::Resource::Font::CoreFont;
@@ -76,7 +76,7 @@
@ISA=qw(PDF::API2::Resource::Font);
- ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.14 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/09/12 16:56:20 $
+ ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.17 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/10/19 19:15:12 $
}
no warnings qw[ deprecated recursion uninitialized ];
@@ -108,9 +108,9 @@
eval "require PDF::API2::Resource::Font::CoreFont::$fname; ";
unless($@)
{
- no strict 'refs';
+ no strict 'refs';
my $obj = "PDF::API2::Resource::Font::CoreFont::".$fname;
- $fonts->{$fname} = deep_copy(${$obj."::FONTDATA"});
+ $fonts->{$fname} = deep_copy(${$obj."::FONTDATA"});
$fonts->{$fname}->{uni}||=[];
foreach my $n (0..255)
{
@@ -133,31 +133,31 @@
my $this = shift;
if (not ref $this)
{
- $this;
+ $this;
}
elsif (ref $this eq "ARRAY")
{
- [map &deep_copy($_), @$this];
+ [map &deep_copy($_), @$this];
}
elsif (ref $this eq "HASH")
{
- +{map { $_ => &deep_copy($this->{$_}) } keys %$this};
+ +{map { $_ => &deep_copy($this->{$_}) } keys %$this};
}
elsif (ref $this eq "CODE")
{
- # Can't deep copy code refs
- return $this;
+ # Can't deep copy code refs
+ return $this;
}
else
{
- die "what type is $_?";
+ die "what type is $_?";
}
}
sub _look_for_fontfile ($)
{
my $fname=shift;
- my $fpath;
+ my $fpath=undef;
foreach my $dir (@INC)
{
$fpath="$dir/PDF/API2/Resource/Font/CoreFont/$fname";
@@ -167,6 +167,19 @@
return($fpath);
}
+sub _look_for_fontmetricfile ($)
+{
+ my $fname=shift;
+ my $fpath=undef;
+ foreach my $dir (@INC)
+ {
+ $fpath="$dir/PDF/API2/Resource/Font/CoreFont/$fname.fm";
+ last if(-f $fpath);
+ $fpath=undef;
+ }
+ return($fpath);
+}
+
sub new
{
my ($class,$pdf,$name, at opts) = @_;
@@ -197,11 +210,11 @@
{
unless(defined $opts{-metrics})
{
- $data={_look_for_font($lookname)};
+ $data={_look_for_font($lookname)};
}
else
{
- $data={%{$opts{-metrics}}};
+ $data={%{$opts{-metrics}}};
}
}
@@ -226,13 +239,13 @@
#}
$class = ref $class if ref $class;
- $self = $class->SUPER::new($pdf, $data->{apiname}.pdfkey());
+ $self = $class->SUPER::new($pdf, $data->{apiname}.pdfkey().'~'.time());
$pdf->new_obj($self) unless($self->is_obj($pdf));
$self->{' data'}=$data;
+ $self->{-dokern}=1 if($opts{-dokern});
$self->{'Subtype'} = PDFName($self->data->{type});
$self->{'BaseFont'} = PDFName($self->fontname);
-
if($opts{-pdfname})
{
$self->name($opts{-pdfname});
@@ -451,6 +464,15 @@
=head1 HISTORY
$Log: CoreFont.pm,v $
+ Revision 1.17 2005/10/19 19:15:12 fredo
+ added handling of optional kerning
+
+ Revision 1.16 2005/10/01 22:41:07 fredo
+ fixed font-naming race condition for multiple document updates
+
+ Revision 1.15 2005/09/26 20:07:19 fredo
+ added fontmetric stub
+
Revision 1.14 2005/09/12 16:56:20 fredo
applied mod_perl patch by Paul Schilling <pfschill at sbcglobal.net>
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/Postscript.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/Postscript.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font/Postscript.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -27,7 +27,7 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
#
-# $Id: Postscript.pm,v 1.9 2005/06/17 19:44:03 fredo Exp $
+# $Id: Postscript.pm,v 1.13 2005/10/19 23:05:17 fredo Exp $
#
#=======================================================================
package PDF::API2::Resource::Font::Postscript;
@@ -48,7 +48,7 @@
@ISA = qw( PDF::API2::Resource::Font );
- ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.9 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/06/17 19:44:03 $
+ ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.13 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/10/19 23:05:17 $
}
no warnings qw[ deprecated recursion uninitialized ];
@@ -81,34 +81,43 @@
}
$class = ref $class if ref $class;
- $self = $class->SUPER::new($pdf, $data->{apiname}.pdfkey());
+ $self = $class->SUPER::new($pdf, $data->{apiname}.pdfkey().'~'.time());
$pdf->new_obj($self) unless($self->is_obj($pdf));
$self->{' data'}=$data;
- $self->{'Subtype'} = PDFName("Type1");
- $self->{'BaseFont'} = PDFName($self->fontname);
-
if($opts{-pdfname}) {
$self->name($opts{-pdfname});
}
+ $self->{'Subtype'} = PDFName("Type1");
$self->{'FontDescriptor'}=$self->descrByData();
+ if(-f $psfile)
+ {
+ $self->{'BaseFont'} = PDFName(pdfkey().'+'.($self->fontname).'~'.time());
- my ($l1,$l2,$l3,$stream)=$self->readPFAPFB($psfile);
+ my ($l1,$l2,$l3,$stream)=$self->readPFAPFB($psfile);
- my $s = PDFDict();
- $self->{'FontDescriptor'}->{'FontFile'} = $s;
- $s->{'Length1'} = PDFNum($l1);
- $s->{'Length2'} = PDFNum($l2);
- $s->{'Length3'} = PDFNum($l3);
- $s->{'Filter'} = PDFArray(PDFName("FlateDecode"));
- $s->{' stream'} = $stream;
- if(defined $pdf) {
- $pdf->new_obj($s);
+ my $s = PDFDict();
+ $self->{'FontDescriptor'}->{'FontFile'} = $s;
+ $s->{'Length1'} = PDFNum($l1);
+ $s->{'Length2'} = PDFNum($l2);
+ $s->{'Length3'} = PDFNum($l3);
+ $s->{'Filter'} = PDFArray(PDFName("FlateDecode"));
+ $s->{' stream'} = $stream;
+ if(defined $pdf) {
+ $pdf->new_obj($s);
+ }
}
+ else
+ {
+ $self->{'BaseFont'} = PDFName($self->fontname);
+ }
$self->encodeByData($opts{-encode});
+ $self->{-nocomps}=1 if($opts{-nocomps});
+ $self->{-dokern}=1 if($opts{-dokern});
+
return($self);
}
@@ -198,7 +207,8 @@
# $datahashref = $self->readAFM( $afmfile );
-sub readAFM {
+sub readAFM
+{
my ($self,$file)=@_;
my $data={};
$data->{wx}={};
@@ -210,10 +220,10 @@
if(! -e $file) {die "file='$file' not existant.";}
open(AFMF, $file) or die "Can't find the AFM file for $file";
local($/, $_) = ("\n", undef); # ensure correct $INPUT_RECORD_SEPARATOR
- while ($_=<AFMF>) {
- next if /^StartKernData/ .. /^EndKernData/; # kern data not parsed yet
- next if /^StartComposites/ .. /^EndComposites/; # same for composites
- if (/^StartCharMetrics/ .. /^EndCharMetrics/) {
+ while ($_=<AFMF>)
+ {
+ if (/^StartCharMetrics/ .. /^EndCharMetrics/)
+ {
# only lines that start with "C" or "CH" are parsed
next unless $_=~/^CH?\s/;
my($ch) = $_=~/^CH?\s+(\d+)\s*;/;
@@ -234,23 +244,55 @@
$data->{firstchar} = $data->{firstchar}>$ch ? $ch : $data->{firstchar};
next;
}
+ elsif(/^StartKernData/ .. /^EndKernData/)
+ {
+ $data->{kern}||={};
+ if($_=~m|^KPX\s+(\S+)\s+(\S+)\s+(\S+)\s*$|i)
+ {
+ $data->{kern}->{"$1:$2"}=$3;
+ }
+ }
+ elsif(/^StartComposites/ .. /^EndComposites/)
+ {
+ $data->{comps}||={};
+ if($_=~m|^CC\s+(\S+)\s+(\S+)\s+;|i)
+ {
+ my ($name,$comp)=($1,$2);
+ my @cv=split(/;/,$_);
+ shift @cv;
+ my $rng=[];
+ foreach (1..$comp)
+ {
+ my @c1=split(/\s+/,shift @cv);
+ push @{$rng},$c1[1],$c1[2],$c1[3];
+ }
+ $data->{comps}->{$name}=$rng;
+ }
+ }
last if $_=~/^EndFontMetrics/;
- if (/(^\w+)\s+(.*)/) {
+ if (/(^\w+)\s+(.*)/)
+ {
my($key,$val) = ($1, $2);
$key = lc $key;
- if (defined $data->{$key}) {
+ if (defined $data->{$key})
+ {
# $data->{$key} = [ $data->{$key} ] unless ref $data->{$key};
# push(@{$data->{$key}}, $val);
- } else {
+ }
+ else
+ {
$val=~s/[\x00\x1f]+//g;
$data->{$key} = $val;
}
- } else {
- print STDERR "Can't parse: $_";
+ }
+ else
+ {
+ ## print STDERR "Can't parse: $_";
}
}
close(AFMF);
- unless (exists $data->{wx}->{'.notdef'}) {
+ unless (exists $data->{wx}->{'.notdef'})
+ {
$data->{wx}->{'.notdef'} = 0;
$data->{bbox}{'.notdef'} = [0, 0, 0, 0];
}
@@ -258,11 +300,15 @@
$data->{avgwidth2} /= scalar keys %{$data->{bbox}} ;
$data->{avgwidth2} = int($data->{avgwidth2});
- $data->{fontname}=~s/[^A-Za-z0-9]+//og;
+ $data->{fontname}=~s/[\x00-\x20]+//og;
+ ## $data->{fontname}=~s/[^A-Za-z0-9]+//og;
- if(defined $data->{fullname}) {
+ if(defined $data->{fullname})
+ {
$data->{altname}=$data->{fullname};
- } else {
+ }
+ else
+ {
$data->{altname}=$data->{familyname};
$data->{altname}.=' Italic' if($data->{italicangle}<0);
$data->{altname}.=' Oblique' if($data->{italicangle}>0);
@@ -286,10 +332,12 @@
$data->{flags} = 34;
$data->{uni}||=[];
- foreach my $n (0..255) {
+ foreach my $n (0..255)
+ {
$data->{uni}->[$n]=uniByName($data->{char}->[$n] || '.notdef') || 0;
}
-
+ delete $data->{bbox};
+
return($data);
}
@@ -522,6 +570,19 @@
=head1 HISTORY
$Log: Postscript.pm,v $
+ Revision 1.13 2005/10/19 23:05:17 fredo
+ silenced 'cannot parse' since it is usually no error
+
+ Revision 1.12 2005/10/19 19:12:35 fredo
+ added handling of optional kerning
+
+ Revision 1.11 2005/10/01 23:38:00 fredo
+ added kerning+composite parsing
+ added nonembedding check
+
+ Revision 1.10 2005/10/01 22:41:07 fredo
+ fixed font-naming race condition for multiple document updates
+
Revision 1.9 2005/06/17 19:44:03 fredo
fixed CPAN modulefile versioning (again)
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/Font.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -27,7 +27,7 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
#
-# $Id: Font.pm,v 1.15 2005/06/17 19:44:03 fredo Exp $
+# $Id: Font.pm,v 1.17 2005/10/19 19:07:15 fredo Exp $
#
#=======================================================================
package PDF::API2::Resource::Font;
@@ -47,7 +47,7 @@
@ISA = qw( PDF::API2::Resource::BaseFont );
- ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.15 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/06/17 19:44:03 $
+ ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.17 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/10/19 19:07:15 $
}
no warnings qw[ deprecated recursion uninitialized ];
@@ -196,35 +196,46 @@
foreach my $n (0..255) {
delete $gl{$self->data->{e2n}->[$n]};
}
+
+ if(defined $self->data->{comps} && !$self->{-nocomps})
+ {
+ foreach my $n (keys %{$self->data->{comps}})
+ {
+ delete $gl{$n};
+ }
+ }
-# my @nm=sort { lc($a) eq lc($b) ? $a cmp $b : lc($a) cmp lc($b) } keys %gl;
- my @nm=sort { $gl{$a}<=>$gl{$b} } keys %gl;
- #splice(@nm,223);
+ my @nm=sort { $gl{$a} <=> $gl{$b} } keys %gl;
+
my @fnts=();
my $count=0;
- while(@glyphs=splice(@nm,0,223)) {
-
+ while(@glyphs=splice(@nm,0,223))
+ {
my $obj=$self->SUPER::new($self->{' apipdf'},$self->name.'am'.$count);
$obj->{' data'}={ %{$self->data} };
$obj->data->{firstchar}=32;
$obj->data->{lastchar}=32+scalar(@glyphs);
push @fnts,$obj;
- foreach my $key (qw( Subtype BaseFont FontDescriptor )) {
+ foreach my $key (qw( Subtype BaseFont FontDescriptor ))
+ {
$obj->{$key}=$self->{$key} if(defined $self->{$key});
}
$obj->data->{char}=[];
$obj->data->{uni}=[];
- foreach my $n (0..31) {
+ foreach my $n (0..31)
+ {
$obj->data->{char}->[$n]='.notdef';
$obj->data->{uni}->[$n]=0;
}
$obj->data->{char}->[32]='space';
$obj->data->{uni}->[32]=32;
- foreach my $n (33..$obj->data->{lastchar}) {
+ foreach my $n (33..$obj->data->{lastchar})
+ {
$obj->data->{char}->[$n]=$glyphs[$n-33];
$obj->data->{uni}->[$n]=$gl{$glyphs[$n-33]};
}
- foreach my $n (($obj->data->{lastchar}+1)..255) {
+ foreach my $n (($obj->data->{lastchar}+1)..255)
+ {
$obj->data->{char}->[$n]='.notdef';
$obj->data->{uni}->[$n]=0;
}
@@ -261,6 +272,12 @@
=head1 HISTORY
$Log: Font.pm,v $
+ Revision 1.17 2005/10/19 19:07:15 fredo
+ added handling of composites in automap
+
+ Revision 1.16 2005/09/26 20:06:02 fredo
+ removed composite glyphs from automap
+
Revision 1.15 2005/06/17 19:44:03 fredo
fixed CPAN modulefile versioning (again)
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/UniFont.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/UniFont.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/UniFont.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -27,7 +27,7 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
#
-# $Id: UniFont.pm,v 1.7 2005/06/17 19:44:03 fredo Exp $
+# $Id: UniFont.pm,v 1.8 2005/10/19 19:08:44 fredo Exp $
#
#=======================================================================
package PDF::API2::Resource::UniFont;
@@ -43,7 +43,7 @@
use vars qw($VERSION);
- ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.7 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/06/17 19:44:03 $
+ ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.8 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/10/19 19:08:44 $
}
no warnings qw[ deprecated recursion uninitialized ];
@@ -213,21 +213,57 @@
my ($self,$text)=@_;
$text=decode($self->{encode},$text) unless(is_utf8($text));
my $width=0;
- foreach my $u (unpack('U*',$text))
+ if(1)
{
- if(defined $self->{code}->{$u})
+ my @blks=();
+ foreach my $u (unpack('U*',$text))
{
- $width+=$self->fontlist->[$self->{code}->{$u}]->width(pack('U',$u));
+ my $fn=0;
+ if(defined $self->{code}->{$u})
+ {
+ $fn=$self->{code}->{$u};
+ }
+ elsif(defined $self->{block}->{($u>>8)})
+ {
+ $fn=$self->{block}->{($u>>8)};
+ }
+ else
+ {
+ $fn=0;
+ }
+ if(scalar @blks==0 || $blks[-1]->[0]!=$fn)
+ {
+ push @blks,[$fn,pack('U',$u)];
+ }
+ else
+ {
+ $blks[-1]->[1].=pack('U',$u);
+ }
}
- elsif(defined $self->{block}->{($u>>8)})
+ foreach my $blk (@blks)
{
- $width+=$self->fontlist->[$self->{block}->{($u>>8)}]->width(pack('U',$u));
+ $width+=$self->fontlist->[$blk->[0]]->width($blk->[1]);
}
- else
+ }
+ else
+ {
+ foreach my $u (unpack('U*',$text))
{
- $width+=$self->fontlist->[0]->width(pack('U',$u));
+ if(defined $self->{code}->{$u})
+ {
+ $width+=$self->fontlist->[$self->{code}->{$u}]->width(pack('U',$u));
+ }
+ elsif(defined $self->{block}->{($u>>8)})
+ {
+ $width+=$self->fontlist->[$self->{block}->{($u>>8)}]->width(pack('U',$u));
+ }
+ else
+ {
+ $width+=$self->fontlist->[0]->width(pack('U',$u));
+ }
}
}
+
return($width);
}
@@ -266,7 +302,8 @@
if(scalar @codes > 0)
{
my $f=$self->fontlist->[$lastfont];
- $newtext.='/'.$f->name.' '.$size.' Tf '.$f->text(pack('U*', at codes)).' Tj ';
+ ## $newtext.='/'.$f->name.' '.$size.' Tf '.$f->text(pack('U*', at codes)).' Tj ';
+ $newtext.='/'.$f->name.' '.$size.' Tf '.$f->text(pack('U*', at codes),$size).' ';
}
return($newtext);
@@ -274,4 +311,4 @@
1;
-__END__
\ No newline at end of file
+__END__
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/XObject/Image/JPEG.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/XObject/Image/JPEG.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/XObject/Image/JPEG.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -27,7 +27,7 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
#
-# $Id: JPEG.pm,v 1.10 2005/06/17 19:44:04 fredo Exp $
+# $Id: JPEG.pm,v 1.11 2005/09/28 17:02:47 fredo Exp $
#
#=======================================================================
package PDF::API2::Resource::XObject::Image::JPEG;
@@ -44,7 +44,7 @@
@ISA = qw( PDF::API2::Resource::XObject::Image );
- ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.10 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/06/17 19:44:04 $
+ ( $VERSION ) = sprintf '%i.%03i', split(/\./,('$Revision: 1.11 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/09/28 17:02:47 $
}
no warnings qw[ deprecated recursion uninitialized ];
@@ -61,7 +61,8 @@
=cut
-sub new {
+sub new
+{
my ($class,$pdf,$file,$name) = @_;
my $self;
my $fh = IO::File->new;
@@ -73,19 +74,25 @@
$self->{' apipdf'}=$pdf;
- if(ref $file) {
+ if(ref $file)
+ {
$fh=$file;
- } else {
+ }
+ else
+ {
open($fh,$file);
}
binmode($fh,':raw');
$self->read_jpeg($fh);
- if(ref($file) eq 'PDF::API2::IOString') {
- $self->{' stream'}=$fh->{buf};
+ if(ref($file) eq 'PDF::API2::IOString')
+ {
+ $self->{' stream'}=${*$fh->{buf}};
$self->{Length}=PDFNum(length $self->{' stream'});
- } elsif(ref $file) {
+ }
+ elsif(ref $file)
+ {
seek($fh,0,0);
$self->{' stream'}='';
my $buf='';
@@ -94,7 +101,9 @@
$self->{' stream'}.=$buf;
}
$self->{Length}=PDFNum(length $self->{' stream'});
- } else {
+ }
+ else
+ {
$self->{Length}=PDFNum(-s $file);
$self->{' streamfile'}=$file;
}
@@ -175,6 +184,9 @@
=head1 HISTORY
$Log: JPEG.pm,v $
+ Revision 1.11 2005/09/28 17:02:47 fredo
+ fixed iostring handling
+
Revision 1.10 2005/06/17 19:44:04 fredo
fixed CPAN modulefile versioning (again)
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/uniglyph.txt
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/uniglyph.txt 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Resource/uniglyph.txt 2005-10-24 17:14:19 UTC (rev 1452)
@@ -16,12 +16,17 @@
0x0007 ; controlBEL ; 6 # Adobe Glyph List (Sept/02) # <control>
0x0008 ; tilde ; 1 # Substitution Candidate
0x0008 ; controlBS ; 6 # Adobe Glyph List (Sept/02) # <control>
-0x0009 ; dotlessi ; 1 # Substitution Candidate
+0x0009 ; breve ; 1 # Substitution Candidate
0x0009 ; controlHT ; 6 # Adobe Glyph List (Sept/02) # <control>
+0x000A ; ogonek ; 1 # Substitution Candidate
0x000A ; controlLF ; 6 # Adobe Glyph List (Sept/02) # <control>
+0x000B ; dotaccent ; 1 # Substitution Candidate
0x000B ; controlVT ; 6 # Adobe Glyph List (Sept/02) # <control>
+0x000C ; hungarumlaut ; 1 # Substitution Candidate
0x000C ; controlFF ; 6 # Adobe Glyph List (Sept/02) # <control>
+0x000D ; cedilla ; 1 # Substitution Candidate
0x000D ; controlCR ; 6 # Adobe Glyph List (Sept/02) # <control>
+0x000E ; dblgrave ; 1 # Substitution Candidate
0x000E ; controlSO ; 6 # Adobe Glyph List (Sept/02) # <control>
0x000F ; controlSI ; 6 # Adobe Glyph List (Sept/02) # <control>
0x0010 ; controlDLE ; 6 # Adobe Glyph List (Sept/02) # <control>
@@ -38,7 +43,9 @@
0x001B ; controlESC ; 6 # Adobe Glyph List (Sept/02) # <control>
0x001C ; controlFS ; 6 # Adobe Glyph List (Sept/02) # <control>
0x001D ; controlGS ; 6 # Adobe Glyph List (Sept/02) # <control>
+0x001E ; dotlessi ; 1 # Substitution Candidate
0x001E ; controlRS ; 6 # Adobe Glyph List (Sept/02) # <control>
+0x001F ; dotlessj ; 1 # Substitution Candidate
0x001F ; controlUS ; 6 # Adobe Glyph List (Sept/02) # <control>
0x0020 ; space ; 0 # Adobe Glyph List FN (v1.3) # SPACE
0x0020 ; spacehackarabic ; 6 # Adobe Glyph List (Sept/02)
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2/Version.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2/Version.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2/Version.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -9,18 +9,18 @@
package PDF::API2::Version;
BEGIN {
use vars qw( $VERSION %CVersion );
- $VERSION = '0.46';
+ $VERSION = '0.49';
%CVersion = (
- 'vFredo' => 'PDF::API2 0.46 (stable-3328 / 2005-09-12)',
- 'vGNU' => 'PDF::API2 0.46 (2005-09-12 18:58:13)',
- 'vHex' => '0x0002ED00',
- 'vLong' => '0.46 (2005-09-12 18:58:13)',
- 'vPerl' => '0.46',
- 'vShort' => '0.46',
- 'vSquid' => '0.46-stable-3328',
- 'vTeX' => 'This is PDF::API2, Version 0.46 (2005-09-12 18:58:13)',
- 'vWeb' => 'PDF::API2/0.46',
- 'vWin' => '0.46 build 3328',
+ 'vFredo' => 'PDF::API2 0.49 (fix-3328 / 2005-10-21)',
+ 'vGNU' => 'PDF::API2 0.49 (2005-10-21 23:48:42)',
+ 'vHex' => '0x00031D00',
+ 'vLong' => '0.49 (2005-10-21 23:48:42)',
+ 'vPerl' => '0.49',
+ 'vShort' => '0.49',
+ 'vSquid' => '0.49-fix-3328',
+ 'vTeX' => 'This is PDF::API2, Version 0.49 (2005-10-21 23:48:42)',
+ 'vWeb' => 'PDF::API2/0.49',
+ 'vWin' => '0.49 build 3328',
);
}
1;
@@ -36,16 +36,16 @@
=head1 VERSION
- vFredo: PDF::API2 0.46 (stable-3328 / 2005-09-12)
- vGNU: PDF::API2 0.46 (2005-09-12 18:58:13)
- vHex: 0x0002ED00
- vLong: 0.46 (2005-09-12 18:58:13)
- vPerl: 0.46
- vShort: 0.46
- vSquid: 0.46-stable-3328
- vTeX: This is PDF::API2, Version 0.46 (2005-09-12 18:58:13)
- vWeb: PDF::API2/0.46
- vWin: 0.46 build 3328
+ vFredo: PDF::API2 0.49 (fix-3328 / 2005-10-21)
+ vGNU: PDF::API2 0.49 (2005-10-21 23:48:42)
+ vHex: 0x00031D00
+ vLong: 0.49 (2005-10-21 23:48:42)
+ vPerl: 0.49
+ vShort: 0.49
+ vSquid: 0.49-fix-3328
+ vTeX: This is PDF::API2, Version 0.49 (2005-10-21 23:48:42)
+ vWeb: PDF::API2/0.49
+ vWin: 0.49 build 3328
=cut
Modified: packages/libpdf-api2-perl/trunk/lib/PDF/API2.pm
===================================================================
--- packages/libpdf-api2-perl/trunk/lib/PDF/API2.pm 2005-10-24 17:12:03 UTC (rev 1451)
+++ packages/libpdf-api2-perl/trunk/lib/PDF/API2.pm 2005-10-24 17:14:19 UTC (rev 1452)
@@ -27,7 +27,7 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
#
-# $Id: API2.pm,v 1.83 2005/09/12 16:54:21 fredo Exp $
+# $Id: API2.pm,v 1.86 2005/10/21 19:51:05 fredo Exp $
#
#=======================================================================
@@ -37,7 +37,7 @@
use vars qw( $VERSION $seq @FontDirs );
- ($VERSION) = sprintf '%i.%03i', split(/\./,('$Revision: 1.83 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/09/12 16:54:21 $
+ ($VERSION) = sprintf '%i.%03i', split(/\./,('$Revision: 1.86 $' =~ /Revision: (\S+)\s/)[0]); # $Date: 2005/10/21 19:51:05 $
@FontDirs = ( (map { "$_/PDF/API2/fonts" } @INC),
qw[ /usr/share/fonts /usr/local/share/fonts c:/windows/fonts c:/winnt/fonts ] );
@@ -715,19 +715,23 @@
$pgs->{Resources}->realise;
};
}
- foreach $pgref ($pgs->{'Kids'}->elementsof) {
- $pg = $pdf->read_obj($pgref);
- if ($pg->{'Type'}->val =~ m/^Pages$/o) {
- push(@pglist, proc_pages($pdf, $pg));
- } else {
+ foreach $pg ($pgs->{'Kids'}->elementsof) {
+ $pg->realise;
+ if ($pg->{'Type'}->val =~ m/^Pages$/o)
+ {
+ my @morepages = proc_pages($pdf, $pg);
+ push(@pglist, @morepages);
+ }
+ else
+ {
$pdf->{' apipagecount'}++;
- $pgref->{' pnum'} = $pdf->{' apipagecount'};
+ $pg->{' pnum'} = $pdf->{' apipagecount'};
if(defined($pg->{Resources})) {
eval {
$pg->{Resources}->realise;
};
}
- push (@pglist, $pgref);
+ push (@pglist, $pg);
}
}
return(@pglist);
@@ -1516,6 +1520,8 @@
'-encode' ... changes the encoding of the font from its default.
+ '-dokern' ... enables kerning if data is available.
+
=cut
sub corefont {
@@ -1553,6 +1559,8 @@
windows printer font metrics file (PFM).
(this option overrides the -encode option)
+ '-dokern' ... enables kerning if data is available.
+
=cut
sub psfont {
@@ -1594,6 +1602,8 @@
'-isocmap' ... per default the MS Unicode Map is used, if this
option is given the ISO Unicode Map will be used.
+ '-dokern' ... enables kerning if data is available.
+
=cut
sub ttfont {
@@ -2404,6 +2414,15 @@
=head1 HISTORY
$Log: API2.pm,v $
+ Revision 1.86 2005/10/21 19:51:05 fredo
+ fixed proc_pages
+
+ Revision 1.85 2005/10/20 21:06:39 fredo
+ documented '-dokern' option for ttfonts
+
+ Revision 1.84 2005/10/19 21:23:26 fredo
+ documented '-dokern' option for core- and psfonts
+
Revision 1.83 2005/09/12 16:54:21 fredo
added -isocmap option
More information about the Pkg-perl-cvs-commits
mailing list