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

Uploaded Python 3

File details

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

File metadata

  • Download URL: markdown_os-0.9.18.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.18.tar.gz
Algorithm Hash digest
SHA256 59d9c91286b52955d56c73c776762d7ea39d4e38aad1ad9f473cbf698018b110
MD5 df50c6a2c6b756035df751b12fd25b18
BLAKE2b-256 a755d6c87f9ad16d6981ab9a6f7348f966c6654f5ac4854dc13e446406fe0822

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: markdown_os-0.9.18-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.18-py3-none-any.whl
Algorithm Hash digest
SHA256 93f173d74123ce285695aa46fa9ebfc06d012e2c09ca7b6f8a8f33ad6218dd48
MD5 dd47452b6e2e7b66b163fe123d2ad76a
BLAKE2b-256 6c0a8dc4b99e5dac8b6f464b6e8fba5319991f9fa4115485037669130e95228a

See more details on using hashes here.

Provenance

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