Commit graph

11 commits

Author SHA1 Message Date
jedarden
b535638104 feat(pdftract-2bsfc): implement document catalog parser with PageLabels number tree
Implement the document catalog parser (/Root traversal) for PDF documents.
The catalog parser extracts all key entries from the document catalog
including Pages, Outlines, MarkInfo, StructTreeRoot, AcroForm, Names,
Metadata, PageLabels, OCProperties, OpenAction, AA, and Version.

Key structures:
- MarkInfo: parses /MarkInfo dictionary with is_tagged, user_properties, suspects
- PageLabelStyle: enum for all label styles (D, R, r, A, a)
- PageLabel: single page label with style, prefix, and start value
- PageLabelsTree: number tree parser for /PageLabels with /Nums and /Kids support
- OcProperties: stub for OCG implementation (delegated to dedicated bead)
- Catalog: main catalog struct with all required and optional fields

Number tree implementation:
- Parses /Nums arrays (leaf nodes with alternating key-value pairs)
- Supports /Kids arrays (internal nodes for recursive tree traversal)
- Provides get_label_with_start() and get_label() methods for lookup
- Correctly formats roman numerals (uppercase/lowercase) and letter sequences

All 27 tests pass including proptests for fuzzing robustness (INV-8).

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-17 23:45:45 -04:00
jedarden
3af009440e fix(pdftract-5z5d8): fix provenance validation script
Fixed scripts/check-provenance.sh to properly validate PROVENANCE.md
against actual fixture files. The script was failing silently due to
subshell EXIT trap removing temp files before parent could read them,
and arithmetic expansion returning exit code 1 on zero value.

Changes:
- Replaced subshell pipes with process substitution
- Moved temp file cleanup to after reading
- Added validated variable initialization
- Added || true to prevent exit on zero arithmetic

All 200 classifier corpus fixtures have valid provenance entries
with matching SHA256 hashes. PROVENANCE.md already existed with
complete documentation.

Refs: pdftract-5z5d8
Co-Authored-By: Claude Code <noreply@anthropic.com>
2026-05-17 23:43:37 -04:00
jedarden
88278c362f feat(pdftract-4hn1): use Cow<'static, str> for diagnostic messages
Changed Diagnostic::msg from String to Cow<'static, str> to avoid
allocations for static error messages. Static messages now use
Cow::Borrowed, while dynamic formatted messages use Cow::Owned.

Also fixed peek_token lifetime issue - was returning reference to
local variable, now returns reference from cache.

Acceptance criteria:
- Token enum with all required variants
- Lexer struct with position tracking and diagnostics
- Diagnostic uses Cow<'static, str> for zero-allocation static messages
- All public methods implemented: new, next_token, peek_token, position, take_diagnostics
- All internal helpers implemented

Refs: pdftract-4hn1

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
Bead-Id: pdftract-4hn1
2026-05-17 23:23:38 -04:00
jedarden
8b5dd4febb docs(pdftract-4iier): add per-profile README documentation for all 9 built-in profiles
This commit creates user-facing documentation for each built-in profile:

- Profile YAML files defining match criteria, priority, and extracted fields
- Per-profile READMEs with match criteria summary, extracted fields table,
  known limitations, sample input pointers, and configuration tips
- xtask skeleton generator for automated README generation

Profiles documented:
- invoice: Commercial invoices with line items, vendor/customer, totals
- receipt: POS receipts with items, payment method
- contract: Legal contracts with parties, effective date, term, signatures
- scientific_paper: Academic papers with title, authors, abstract, DOI, references
- slide_deck: Presentation slides with title, presenter, date, slide titles
- form: Fillable forms (degenerate case: uses Phase 7.4 form_fields)
- bank_statement: Bank statements with account info, period, balances, transactions
- legal_filing: Court filings with case number, court, parties, filing date, docket
- book_chapter: Book chapters with title, chapter number, author, section headings

Closes: pdftract-4iier
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-17 23:19:00 -04:00
jedarden
5e66846288 docs(pdftract-147a): author SDK contract specification
Add comprehensive SDK contract specification at docs/notes/sdk-contract.md.
This document serves as the constitutional specification for all pdftract
SDK implementations across all languages.

The contract defines:
- Method surface (9 methods mirroring CLI/MCP tools)
- Error mapping (CLI exit codes → native exceptions)
- Versioning compatibility rules (MAJOR lock, MINOR flexibility)
- Option-naming conventions (CLI flag → language-native case)
- Native type-mapping requirements (Document, Page, Span, Block, Match, Fingerprint, Classification)
- Async conventions per language
- Conformance enforcement (100% pass required)
- Change policy (ADR required for contract changes)

Verification note: notes/pdftract-147a.md

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-17 23:13:55 -04:00
jedarden
1747812323 docs(pdftract-1wqec): verify CI scaffolding acceptance criteria
- Confirm pdftract-ci.yaml exists in declarative-config
- Verify WorkflowTemplate deployed to argo-workflows namespace
- Document all scaffold templates are present with placeholders
- Note: ArgoCD sync will reconcile minor version drift

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-17 07:12:16 -04:00
jedarden
891718319e docs(pdftract-1wqec): verify manual workflow execution succeeds
Updated verification notes with successful manual workflow test results.
All DAG steps completed successfully; publish-if-tag correctly skipped.
2026-05-17 07:06:38 -04:00
jedarden
5a6449a8cf docs(phase-0.1): verify pdftract-ci scaffolding complete
The pdftract-ci WorkflowTemplate was already created in declarative-config
in a previous session. This commit adds verification notes confirming all
acceptance criteria are met:

- WorkflowTemplate exists in k8s/iad-ci/argo-workflows/pdftract-ci.yaml
- Template synced to iad-ci cluster (argo-workflows namespace)
- DAG structure: setup -> [build-matrix, test-matrix, quality-matrix,
  bench-matrix] -> publish-if-tag
- All required configuration present (parameters, securityContext,
  volumeClaimTemplates, podGC, TTL)
- Webhook payload schema documented in YAML comments
- Empty step skeletons ready for Phase 0 sibling beads

Manual workflow test attempted but encountered transient Rackspace Spot
CSI storage attachment issue (infrastructure, not template defect).

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-17 06:58:21 -04:00
jedarden
9f27d16f25 docs(phase-0.1): verify pdftract-ci scaffolding complete
Verified the pdftract-ci WorkflowTemplate exists in declarative-config
and is correctly synced to the iad-ci cluster. All scaffolding
requirements met for Phase 0.1.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-17 03:24:36 -04:00
jedarden
f2bf29b0c8 docs(Phase 0.1): document pdftract-ci scaffold status
Verify completion of Phase 0.1 scaffolding bead. The WorkflowTemplate
was already implemented in declarative-config with all required elements:
- DAG structure with empty step skeletons
- VolumeClaimTemplates for cargo cache
- Exit handler, security context, imagePullSecrets
- Webhook payload schema documentation

Subsequent Phase 0 beads can now develop each DAG leg in parallel.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-17 02:43:48 -04:00
jedarden
427c353fbc docs(Phase 0.1): document pdftract-ci scaffold status
The pdftract-ci.yaml WorkflowTemplate scaffold already exists in
declarative-config (commit 8248a1f). This notes file documents the
current state and pending ArgoCD sync.

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-17 01:52:42 -04:00