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.17.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.17-py3-none-any.whl (2.4 MB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: markdown_os-0.9.17.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.17.tar.gz
Algorithm Hash digest
SHA256 9560543fbe8215780fdb29ba7e6a494ffa2e7a0e49deb26ad7fcf13d2d6f40b7
MD5 d07fc46ed69ea9c67353568effb62f2a
BLAKE2b-256 cfd87b307cb081686a7c5f4264987076296952e18f1a0212ebebbbfb3f662d19

See more details on using hashes here.

Provenance

The following attestation bundles were made for markdown_os-0.9.17.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.17-py3-none-any.whl.

File metadata

  • Download URL: markdown_os-0.9.17-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.17-py3-none-any.whl
Algorithm Hash digest
SHA256 efc753a26865c8dfb17a1c492fc23b85fa58e35d6b37430ddd98b7b037e6daff
MD5 447d0fe2c067baa619a483d223827de2
BLAKE2b-256 7f30fccfd824d0b4bc6f91d0c15b247d173d6a3489c28dc3631f7bf8ece52c84

See more details on using hashes here.

Provenance

The following attestation bundles were made for markdown_os-0.9.17-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