Skip to content

RareBird15/bible-reader

Repository files navigation

Bible Reader

A lightweight terminal workflow for daily Bible reading.

This project stores a day-by-day reading plan, shows one day at a time, and tracks your progress using standard Linux (XDG) directories.

What This Project Does

  • Imports a WorldBiblePlans-style EPUB into a normalized markdown plan.
  • Splits a full markdown plan into one file per day with commentary.
  • Extracts scripture-only files from commentary files.
  • Shows today's reading in the terminal and optionally advances your day counter.
  • Includes a command to prompt you to read only once per day, perfect for your shell startup file.

Project Structure

  • plan.md: Source markdown reading plan (generated or provided by you).
  • days-commentary/: Per-day files containing label, reference, scripture, and commentary.
  • days/: Per-day scripture-only files.
  • src/bible_reader/: The core Python package containing all script logic.
  • tests/: Unit tests for the package.

Local State Files (XDG Standards)

This project respects standard Linux directory structures to keep your home folder clean. Your reading progress and prompt history are stored here:

  • Reading Progress: ~/.local/share/bible-reader/current_day.txt
  • Daily Prompt Stamp: ~/.local/state/bible-reader/last_prompt_date.txt

If you ever need to reset your local progress, you can edit or delete those specific files.

Requirements

  • Python 3.11+
  • uv (Recommended for installation and dependency management)

Installation

This project is built as a modern Python package.

  1. Clone the repository and move into the project directory:

    git clone [https://github.com/RareBird15/bible-reader.git](https://github.com/RareBird15/bible-reader.git)
    cd bible-reader
  2. Install the package and its dependencies using uv. The -e flag installs it in "editable" mode so any changes you pull from GitHub apply immediately.

    uv pip install -e .

    Note: If you do not use uv, standard pip install -e . will also work.

Once installed, the tools are available as global terminal commands.

Project Status

This project is actively developed.

Development cadence may be uneven, and there may be periods of slower progress or pauses due to health limitations. Bug reports and well-scoped contributions are still welcome during those periods.

Accessibility

Accessibility is a core project goal.

This project aims to provide an easy, low-friction, screen-reader-friendly way to read the Bible in a terminal workflow.

When changing output, prompts, or documentation, prefer:

  • plain, readable text over decorative formatting.
  • predictable headings and labels.
  • wording that makes sense when read aloud by a screen reader.
  • output that does not rely on visual alignment, color, or ASCII art to communicate meaning.

Contributors should treat regressions in accessibility as real regressions, not cosmetic issues.

Development Checks

Run these checks locally before committing:

uv run ruff check .
uv run python3 -m unittest discover tests -v

Quick Start (Daily Workflow)

Because this is a Python package, you no longer need to type python3 path/to/script.py. You can use the installed commands from anywhere in your terminal.

1. One-Time Setup (From EPUB)

If you are starting from a new WorldBiblePlans EPUB, run this sequence from the project root:

import-epub /path/to/plan.epub --output plan.md
split-plan
extract-scripture

2. Daily Reading

To read today's passage:

bible-reader

When prompted:

  • Enter y to mark the reading complete and advance to the next day.
  • Enter n to keep your current day.

3. Shell Integration (Read Once Per Day)

If you want your terminal to prompt you to read when you open it, but only once per day, add this command to your .bashrc or .zshrc:

maybe-read-bible

Command Reference

All commands support a --debug flag for verbose troubleshooting output.

import-epub

Usage: import-epub /path/to/plan.epub --output plan.md

  • Reads EPUB spine order from the package document.
  • Detects day pages from h1 headings like Day N:.
  • Writes normalized sections with scripture and commentary ## headings.

split-plan

Usage: split-plan

  • Splits plan.md and writes days-commentary/day0001.txt, day0002.txt, etc.
  • Validates each non-cover section has at least two ## headings.

extract-scripture

Usage: extract-scripture

  • Extracts the text between the first and second ## headings from the commentary files.
  • Writes scripture-only files into days/ with matching day filenames.

bible-reader

Usage: bible-reader

  • Initializes current_day.txt in your XDG Data directory if missing.
  • Prints the day label, reference, and scripture text.
  • Prompts to mark complete and increments the counter on y.
  • Uses a file lock to prevent multiple terminal tabs from overwriting your progress concurrently.

maybe-read-bible

Usage: maybe-read-bible

  • Uses a date stamp in your XDG State directory to avoid prompting more than once per calendar date.
  • Updates the stamp only when you mark the reading complete (y).
  • Delegates locking and reading logic to the main bible-reader workflow.

Plan Source and Compatibility

The EPUB import flow is designed specifically for plans from WorldBiblePlans.com:

Current compatibility target:

  • Plans that include full Bible text plus commentary in each day page.

Known-compatible sample:

  • New-Living-Translation-2015-Chuck-Smith-Commentary-Gen-to-Rev-Scriptures-1-Chapter-Daily-Verse-By-Day.epub

Important limitation: Other EPUB layouts (e.g., plans without commentary, alternate heading structures) are not guaranteed to parse correctly as they have not been broadly tested.

Copyright and Content Notice

This repository is intended to distribute tooling only.

  • Do not commit or publish copyrighted plan content (for example EPUB source files, generated plan.md, days/, or days-commentary/) unless you have explicit rights to do so.
  • The repository ignores those content paths by default so they stay local.
  • Users should provide their own plan files and are responsible for ensuring they have permission to use that content.

About

Terminal-first Python toolkit to import compatible WorldBiblePlans EPUBs, generate daily scripture/commentary files, and track reading progress.

Topics

Resources

License

Contributing

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages