Skip to content

Commit 24b3a8f

Browse files
ROB: Fix merging documents if there are no Dests (#3280)
Closes #3279.
1 parent e314629 commit 24b3a8f

File tree

2 files changed

+23
-2
lines changed

2 files changed

+23
-2
lines changed

pypdf/_writer.py

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2796,8 +2796,8 @@ def _process_named_dests(dest: Any) -> None:
27962796
List[Any],
27972797
cast(
27982798
DictionaryObject,
2799-
cast(DictionaryObject, self._root_object["/Names"])["/Dests"],
2800-
)["/Names"],
2799+
cast(DictionaryObject, self._root_object["/Names"]).get("/Dests", DictionaryObject()),
2800+
).get("/Names", DictionaryObject()),
28012801
):
28022802
# already exists: should not duplicate it
28032803
pass

tests/test_writer.py

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@
77
from pathlib import Path
88
from tempfile import NamedTemporaryFile
99
from typing import Any
10+
from unittest import mock
1011

1112
import pytest
1213

@@ -23,6 +24,7 @@
2324
from pypdf.generic import (
2425
ArrayObject,
2526
ContentStream,
27+
Destination,
2628
DictionaryObject,
2729
Fit,
2830
IndirectObject,
@@ -2693,3 +2695,22 @@ def test_compress_identical_objects__after_remove_images():
26932695
writer = PdfWriter(clone_from=RESOURCE_ROOT / "AutoCad_Diagram.pdf")
26942696
writer.remove_images()
26952697
writer.compress_identical_objects(remove_identicals=True, remove_orphans=True)
2698+
2699+
2700+
def test_merge__process_named_dests__no_dests_in_source_file():
2701+
"""Test for #3279"""
2702+
writer = PdfWriter(clone_from=RESOURCE_ROOT / "crazyones.pdf")
2703+
2704+
# Hacky solution to avoid attribute errors.
2705+
names = DictionaryObject()
2706+
names.indirect_reference = names
2707+
writer.root_object[NameObject("/Names")] = names
2708+
2709+
reader = PdfReader(RESOURCE_ROOT / "hello-world.pdf")
2710+
destination = Destination(title="test.pdf", page=reader.pages[0], fit=Fit("/Fit"))
2711+
with mock.patch.object(reader, "_get_named_destinations", return_value={"test.pdf": destination}):
2712+
writer.append(reader)
2713+
# The page now points to the appended one.
2714+
assert writer.named_destinations == {
2715+
"test.pdf": Destination(title="test.pdf", page=writer.pages[1].indirect_reference, fit=Fit("/Fit"))
2716+
}

0 commit comments

Comments
 (0)