Skip to main content

If you are not writing it, you should at least read it.

Project description

vibemark

Track how much code you have actually read, by file and by LOC. vibemark scans your repository for source files, stores progress in a local state file, and provides simple commands to update or visualize your reading status.

Installation

The main way to use vibemark is via PyPI under the vibemark package:

  • pipx install vibemark
  • pip install vibemark
  • uv tool install vibemark (recommended)

Quickstart

  • Scan the repo and initialize progress:
    • vibemark scan
  • Show overall progress and largest remaining files:
    • vibemark stats
    • vibemark stats --top 30 / vibemark stats --all
    • vibemark stats --no-table (totals only)
    • vibemark stats --format csv|tsv (machine-readable output)
  • Mark a file as fully read:
    • vibemark done src/vibemark/cli.py
  • Set partial progress for a file:
    • vibemark set src/vibemark/cli.py 120
  • Exclude a folder for a run (glob):
    • vibemark scan --exclude "src/vendor/*"
  • Persistently exclude a folder (saved in .vibemark.json):
    • vibemark exclude add "src/vendor/*"

More commands

  • vibemark update re-scan and optionally reset changed files
  • vibemark update --reset-changed yes|no skip per-file prompts (default: ask)
  • vibemark reset path/to/file.py mark a file unread
  • vibemark export-md export a markdown checklist
  • vibemark exclude remove|list|clear
  • vibemark ext add|remove|list|clear
  • vibemark --version

How it works

vibemark looks for files matching the configured extensions (default: py) under the repo root, applies default exclusions (e.g., .git/, .venv/, build/), and writes state to .vibemark.json in the root directory. You can add saved exclude globs like src/vendor/* or pass --exclude to a single scan. You can also include other extensions via --ext or the vibemark ext subcommands. Use vibemark update to rescan and optionally reset progress for changed files. For finer control, scan/update accept --loc-mode (physical|nonempty) and --include-empty.

Development

  • Run the CLI:
    • uv run vibemark --help
  • Run tests:
    • uv run pytest

Requirements

  • Python 3.13+
  • uv for running and building from source

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

vibemark-1.3.6.tar.gz (8.6 kB view details)

Uploaded Source

Built Distribution

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

vibemark-1.3.6-py3-none-any.whl (9.7 kB view details)

Uploaded Python 3

File details

Details for the file vibemark-1.3.6.tar.gz.

File metadata

  • Download URL: vibemark-1.3.6.tar.gz
  • Upload date:
  • Size: 8.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.9 {"installer":{"name":"uv","version":"0.9.9"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for vibemark-1.3.6.tar.gz
Algorithm Hash digest
SHA256 5b428c884451778bf6851eeed71154e11436634d2bda5db394d96ed773d4a96e
MD5 27fab446c808b39cb0517bf9209f3e73
BLAKE2b-256 91e70d024c715e0acab943e3741b624711d82824a7a50bfdcf95214760dc010b

See more details on using hashes here.

File details

Details for the file vibemark-1.3.6-py3-none-any.whl.

File metadata

  • Download URL: vibemark-1.3.6-py3-none-any.whl
  • Upload date:
  • Size: 9.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.9 {"installer":{"name":"uv","version":"0.9.9"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for vibemark-1.3.6-py3-none-any.whl
Algorithm Hash digest
SHA256 51b1ae1cba4a6ae556e07175ea4e8fab549c24556f9c2877f535b7f31c680480
MD5 824c9753bd28a3c3e222095fd16732d7
BLAKE2b-256 90e5c497a19bd9068bb56e096291fd5ab8d45b48842eaef1be3ebae571d2a3ef

See more details on using hashes here.

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