BUG: Fix PdfReadError when xref table contains comments before trailer#3710
Merged
stefan6419846 merged 1 commit intopy-pdf:mainfrom Apr 7, 2026
Merged
Conversation
Some PDF producers (e.g. Vectorizer.AI) insert legal PDF comments (% to end of line) between the last xref table entry and the `trailer` keyword. The `_read_standard_xref_table` method did not skip comments at this position, causing it to misparse the `%` character and ultimately raise `PdfReadError: Could not read Boolean object`. The fix adds a loop after reading xref entries that calls `skip_over_comment()` to consume any comment lines before checking for the `trailer` tag. This is consistent with PDF spec §7.2.3 which allows comments anywhere except inside strings or streams.
Codecov Report✅ All modified and coverable lines are covered by tests. Additional details and impacted files@@ Coverage Diff @@
## main #3710 +/- ##
=======================================
Coverage 97.43% 97.43%
=======================================
Files 55 55
Lines 10016 10022 +6
Branches 1841 1842 +1
=======================================
+ Hits 9759 9765 +6
Misses 149 149
Partials 108 108 ☔ View full report in Codecov by Sentry. 🚀 New features to boost your workflow:
|
stefan6419846
added a commit
that referenced
this pull request
Apr 10, 2026
## What's new ### Security (SEC) - Disallow custom XML entity declarations for XMP metadata (#3724) by @stefan6419846 ### New Features (ENH) - Skip MD5 key derivation for AES-256 encrypted PDFs (#3694) by @Ygnas ### Bug Fixes (BUG) - Use remove_orphans in compress_identical_objects (#3310) by @j-t-1 - Fix PdfReadError when xref table contains comments before trailer (#3710) by @rassie - Correctly verify AES padding during decryption (#3699) by @stefan6419846 - Fix stale object cache from non-authoritative object streams (#3698) by @astahlman - Fix extract_links pairing when annotations include non-links (#3687) by @ReinerBRO ### Documentation (DOC) - Add AI policy (#3717) by @stefan6419846 [Full Changelog](6.9.2...6.10.0)
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Closes #3709.
Summary
%to EOL) between xref table entries and thetrailerkeyword in_read_standard_xref_tablePdfReadError: Could not read Boolean objectbecauseread_non_whitespace()stops at%and the parser misinterpretstraileras a boolean tokenChanges
pypdf/_reader.py: Added a loop after reading xref entries that callsskip_over_comment()to consume any comment lines before checking for thetrailertagtests/test_reader.py: Addedtest_xref_table_with_comments_before_trailerwith an inline minimal PDF reproducer containing comment lines between xref entries and trailerTest plan
test_xref_table_with_comments_before_trailerpasses