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

Uploaded Python 3

File details

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

File metadata

  • Download URL: markdown_os-0.9.20.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.20.tar.gz
Algorithm Hash digest
SHA256 12c0a550ed0322906426b7695a854eb8950c7f1542b28f71e06bebb4958dfbfc
MD5 fdc5b5b76b4106a4a790ba29a56e6210
BLAKE2b-256 294e56992752a333bb064099e88d72c2676daf3c8bd60c21aee931d32be6b03d

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: markdown_os-0.9.20-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.20-py3-none-any.whl
Algorithm Hash digest
SHA256 0683c17b02292d4a472be14589f0ee906f4735f7235d52318fdef3f9252cec63
MD5 bcbd9c6074f4ce4ac41f3f9992fe67a2
BLAKE2b-256 6c1d1c4b62a017662e981d87a08650966561c17ee85fba52ef8988240337cbca

See more details on using hashes here.

Provenance

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