Skip to main content

Developer-focused markdown editor served from a local CLI.

Project description

Markdown-OS

PyPI version

Developer-focused markdown editor that runs as a local web server. Edit in the browser with live preview, Mermaid diagrams, syntax highlighting, and auto-save.

Desktop installers for macOS and Windows are published from GitHub Releases. The desktop app bundles the local server and opens with a picker-first workflow, so users do not need Python or a terminal after installation.

Install

pip install markdown-os

Or with uv:

uv tool install markdown-os

To upgrade after installing with uv: uv tool upgrade markdown-os

Desktop app

Download the latest desktop installers from GitHub Releases:

  • macOS: .dmg
  • Windows: .exe

The desktop app keeps the same editor UI, but launches in a native desktop shell with recent files/folders and native open dialogs.

Usage

Single file:

markdown-os open ./notes.md

Directory (markdown workspace):

markdown-os open ./my-notes

The app opens in your browser. If port 8000 is in use, the next port is tried. Options: --host, --port.

Example file

Generate a showcase markdown file:

markdown-os example                    # creates example.md in current directory
markdown-os example ./docs/showcase.md # custom path
markdown-os example --open             # generate and open in the editor

Use --force / -f to overwrite an existing file without prompting.

Publishing (maintainers)

Use the release helper from a clean working tree on the branch you want to publish (usually master):

uv run python scripts/release.py

It reads [project].version from pyproject.toml, asks whether to bump major, minor, or patch, updates the file, then runs git add / git commit (only pyproject.toml) / git push -u origin <current-branch> / annotated git tag / git push origin <tag>.

Useful options:

  • --dry-run — print the planned version and git steps without changing files or running git.
  • -y / --yes — skip the final confirmation prompt.
  • --version X.Y.Z — set an exact version string and skip the bump menu.
  • --branch master — push a specific branch (defaults to your current branch).
  • --repo /path/to/checkout — run against another clone.
  • --allow-dirty — proceed when other files are modified (still only commits pyproject.toml).

Manual sequence (equivalent when you are on master):

  1. Bump version in pyproject.toml.
  2. Commit and push: git add pyproject.toml && git commit -m "chore: release X.Y.Z" && git push origin master
  3. Tag and push: git tag -a vX.Y.Z -m "Release X.Y.Z" && git push origin vX.Y.Z

The GitHub workflow runs on tag push and publishes to PyPI only when the tag matches the package version.

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

markdown_os-0.9.15.tar.gz (101.3 MB view details)

Uploaded Source

Built Distribution

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

markdown_os-0.9.15-py3-none-any.whl (2.4 MB view details)

Uploaded Python 3

File details

Details for the file markdown_os-0.9.15.tar.gz.

File metadata

  • Download URL: markdown_os-0.9.15.tar.gz
  • Upload date:
  • Size: 101.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for markdown_os-0.9.15.tar.gz
Algorithm Hash digest
SHA256 c291d667258ed42b3d63c4d0e9c7d450e0937d1a33386b87bdd6dde234e7a137
MD5 48cb13ff24b435ab24e60dcc96d766ea
BLAKE2b-256 90b3a04a75ce807649530ba43111a644a1488578fe4f5547379db6c9ef1af68a

See more details on using hashes here.

Provenance

The following attestation bundles were made for markdown_os-0.9.15.tar.gz:

Publisher: publish.yml on elena-cabrera/markdown-os

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

File details

Details for the file markdown_os-0.9.15-py3-none-any.whl.

File metadata

  • Download URL: markdown_os-0.9.15-py3-none-any.whl
  • Upload date:
  • Size: 2.4 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for markdown_os-0.9.15-py3-none-any.whl
Algorithm Hash digest
SHA256 c97aaa6653d63f342638a560d62f08c7c07f94cd3e38333fffd7284d8fa8aca2
MD5 ea09bef1f1488e7b767cfc6fc9738e60
BLAKE2b-256 dc9b136feeaf2b0326cb93086cc44802bf76bc9d5e276115d21bde1f1ca42f58

See more details on using hashes here.

Provenance

The following attestation bundles were made for markdown_os-0.9.15-py3-none-any.whl:

Publisher: publish.yml on elena-cabrera/markdown-os

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