From fa6153e6481adf58a94d625b71c8e8733ec3861d Mon Sep 17 00:00:00 2001 From: David Warring Date: Wed, 21 Aug 2024 07:58:36 +1200 Subject: [PATCH] Ensure named destinations are unique --- lib/PDF/API6.rakumod | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) diff --git a/lib/PDF/API6.rakumod b/lib/PDF/API6.rakumod index e9a6733..ab91af8 100644 --- a/lib/PDF/API6.rakumod +++ b/lib/PDF/API6.rakumod @@ -70,15 +70,27 @@ class PDF::API6:ver<0.2.8> $.protect: { $!preferences //= PDF::API6::Preferences.new: :$.catalog }; } + method !unique-dest-name($name) { + my $gen-name = $name; + my Int $n; + while $.destinations{$gen-name}:exists { + $gen-name = $name ~ '_' ~ ++$n; + } + $gen-name; + } + + my subset DestName where PDF::COS::Name|PDF::COS::ByteString; #| Make a miscellaneous named destination - multi method destination(Str:D :$name! is copy, |c) { + multi method destination(Str:D :$name!, |c --> DestName:D) { my PDF::Destination $dest = $.destination: |c; - given $name { - $_ = PDF::COS::Name.COERCE($_) - unless $_ ~~ PDF::COS::Name|PDF::COS::ByteString; + $.protect: { + given self!unique-dest-name($name) { + $.destinations{$_} = $dest; + $_ ~~ DestName + ?? $_ + !! PDF::COS::Name.COERCE($_) + } } - $.protect: { $.destinations{$name} = $dest }; - $name; } #| Make a remote destination to a page (by number) in another PDF file