Skip to main content

Ingram Lightning Source PDF compliance checker and fixer

Project description

ingram-check

A command-line tool that checks PDF files for Ingram Lightning Source compliance and auto-fixes common issues.

Requirements

  • Python 3.11+
  • Ghostscript (gs) — optional; use --use-ghostscript to prefer it over the native Python backend

Installation

# Install with uv (recommended)
uv tool install .

# Or install in a virtual environment
uv sync

After installation, the ingram-check command is available globally.

Usage

Interior PDFs

# Basic check — auto-detects page size
ingram-check interior book.pdf

# Specify trim size and color type
ingram-check interior book.pdf -t 6x9 -c bw

# With bleed
ingram-check interior book.pdf -t 6x9 --bleed

# Auto-fix (ICC removal, color conversion, crop stripping, downsampling, etc.)
ingram-check interior book.pdf --fix

# Unsafe fixes (includes upsampling low-res images)
ingram-check interior book.pdf --fix-unsafe

# JSON output
ingram-check interior book.pdf --format json

If --trim-size is omitted, the tool detects the page size from the PDF and reports it. An error is shown only if pages have inconsistent dimensions.

Trim sizes can be specified as dimensions (6x9, 5.5x8.5) or aliases (trade, a5, letter, digest, royal, mass market).

Cover PDFs

ingram-check cover cover.pdf -t 6x9
ingram-check cover cover.pdf -t 6x9 -b casewrap --fix

Listing checks

ingram-check interior --list-checks
ingram-check cover --list-checks

Individual checks can be toggled with -e (enable) and -d (disable):

ingram-check interior book.pdf -e bracketed_text -d margins

Checks

Interior (15 checks)

Check Severity Auto-fixable
Font embedding Error
Page count (must be even) Error Yes
Page size consistency Error
Bleed dimensions Error
ICC profile removal Error Yes
Spot color removal Error Yes
Color space (Grayscale/CMYK) Error Yes
Crop/registration marks Error Yes
Ink density (warn 240%, error 300%) Error
Image resolution Error/Warning Yes*
Manufacturing statements Error
Paper certification claims Error
Bracketed text Warning
Margins (0.5" recommended) Warning
PDF/X compliance Warning

*Downsampling high-res images is a safe fix (--fix). Upsampling low-res images requires --fix-unsafe.

Cover (9 checks)

Font embedding, page count, cover size, ICC profiles, spot colors, color space, ink density, resolution, and barcode (manual verification).

Auto-fix

--fix applies safe, lossless corrections:

  • Pad odd page count with a blank page
  • Remove ICC profiles from page resources and image XObjects
  • Convert spot colors to CMYK
  • Convert RGB to Grayscale or CMYK
  • Strip crop/registration marks by setting CropBox = TrimBox
  • Downsample images above 375ppi to 300ppi

--fix-unsafe additionally applies fixes that may degrade quality:

  • Upsample images below 300ppi (adds pixels via bicubic interpolation, but no real detail)

Fixed PDFs are written to <filename>_fixed.pdf in the same directory.

By default, all fixes use native Python (pikepdf + Pillow). Pass --use-ghostscript to use Ghostscript's pdfwrite device instead.

License

MIT — see LICENSE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ingram_checker-0.1.3.tar.gz (76.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ingram_checker-0.1.3-py3-none-any.whl (42.7 kB view details)

Uploaded Python 3

File details

Details for the file ingram_checker-0.1.3.tar.gz.

File metadata

  • Download URL: ingram_checker-0.1.3.tar.gz
  • Upload date:
  • Size: 76.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ingram_checker-0.1.3.tar.gz
Algorithm Hash digest
SHA256 8ab80de029984c097781fd6e07a49207de60f5e119c76af396dc7a9073ffbc99
MD5 2a0550bb3bf4d1066d48eac5b1e5e4c0
BLAKE2b-256 488215f07b8f88f808ee0a179703def4ebb15096c65cbc84be25f326a8e6c03c

See more details on using hashes here.

Provenance

The following attestation bundles were made for ingram_checker-0.1.3.tar.gz:

Publisher: release.yml on saggingmeniscus/ingram-check

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ingram_checker-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: ingram_checker-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 42.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ingram_checker-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 16c94792295cb4a1236926a2dfbcf55df75af08407de4e139416609dd9a8855c
MD5 3b32f817c3a117aa17da43cde1b88585
BLAKE2b-256 c1d8987e8d6a0699e68cab12db4027828a0ca24d54b81b6606b00a61558f5824

See more details on using hashes here.

Provenance

The following attestation bundles were made for ingram_checker-0.1.3-py3-none-any.whl:

Publisher: release.yml on saggingmeniscus/ingram-check

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page