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

Homebrew (macOS)

brew tap saggingmeniscus/tap
brew install ingram-check

PyPI

pip install ingram-checker
# or
uv tool install ingram-checker

Standalone binary (macOS Apple Silicon)

Download ingram-check-macos-arm64.tar.gz from the latest release, extract it, and run ./ingram-check from the extracted directory. No Python installation required.

From source

git clone https://github.com/saggingmeniscus/ingram-check.git
cd ingram-check
uv tool install .

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.6.tar.gz (82.6 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.6-py3-none-any.whl (45.3 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for ingram_checker-0.1.6.tar.gz
Algorithm Hash digest
SHA256 0875f463896706dc45d54f43cf36ee3fe5dea668bcb9aead72220b2c7110edff
MD5 4af63f0cda22f7c6f5e64dd9075b9227
BLAKE2b-256 1fc029c6a5fff52924d3aa225e96b7f5552dd3a7bd37502cf528aee6c9b2c199

See more details on using hashes here.

Provenance

The following attestation bundles were made for ingram_checker-0.1.6.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.6-py3-none-any.whl.

File metadata

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

File hashes

Hashes for ingram_checker-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 8ca8baf351bba5ba4acd6676c2d15290288173cb8299e54afae4306e448ecc11
MD5 b0508806c617789e76030b4ec14dc218
BLAKE2b-256 300bc3ba228d58b05f4f65bd7b67dfd6876b1aee28f9a4ab54fc1364a169026c

See more details on using hashes here.

Provenance

The following attestation bundles were made for ingram_checker-0.1.6-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