Skip to main content

An mdformat plugin for space control: EditorConfig indentation, tight lists, and frontmatter spacing.

Project description

mdformat-space-control

Build Status PyPI version

An mdformat plugin that provides unified control over Markdown spacing:

  • EditorConfig support: Configure list indentation via .editorconfig files
  • Tight list formatting: Automatically removes unnecessary blank lines between list items
  • Frontmatter spacing: Normalizes spacing after YAML frontmatter (works with mdformat-frontmatter)
  • Trailing whitespace removal: Strips trailing whitespace outside code blocks
  • Escaped link repair: Fixes malformed multi-line links from web-clipped content

Installation

pip install mdformat-space-control

Or with pipx for command-line usage:

pipx install mdformat
pipx inject mdformat mdformat-space-control

Usage

After installation, mdformat will automatically use this plugin:

mdformat your-file.md

EditorConfig Support

Create an .editorconfig file in your project:

# .editorconfig
root = true

[*.md]
indent_style = space
indent_size = 4

Nested lists will use the configured indentation:

Before:

- Item 1
  - Nested item
- Item 2

After (with 4-space indent):

- Item 1
    - Nested item
- Item 2

Tight List Formatting

Lists with single-paragraph items are automatically formatted as tight lists:

Before:

- Item 1

- Item 2

- Item 3

After:

- Item 1
- Item 2
- Item 3

Multi-paragraph items preserve loose formatting:

- First item with multiple paragraphs

  Second paragraph of first item

- Second item

Frontmatter Spacing

When used with mdformat-frontmatter, this plugin removes blank lines between the frontmatter closing delimiter and the first content block:

Before:

---
title: My Document
---


# Introduction

After:

---
title: My Document
---
# Introduction

Install both plugins for this feature:

pip install mdformat-space-control mdformat-frontmatter

EditorConfig Properties

Property Status Notes
indent_style Supported space or tab for list indentation
indent_size Supported Number of spaces per indent level
tab_width Supported Used when indent_size = tab

Python API

When using the Python API, you can set the file context for EditorConfig lookup:

import mdformat
from mdformat_space_control import set_current_file

set_current_file("/path/to/your/file.md")
try:
    result = mdformat.text(markdown_text, extensions={"space_control"})
finally:
    set_current_file(None)

Compatible Plugins

This plugin is tested to work alongside:

For formatting files in an Obsidian vault, installing mdformat-frontmatter and mdformat-wikilink alongside this plugin is recommended:

pip install mdformat-space-control mdformat-frontmatter mdformat-wikilink

Development

# Install dependencies
uv sync

# Run tests
uv run python -m pytest

# Run with coverage
uv run python -m pytest --cov=mdformat_space_control

License

MIT - see LICENSE file for details.

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

mdformat_space_control-0.1.3.tar.gz (20.5 kB view details)

Uploaded Source

Built Distribution

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

mdformat_space_control-0.1.3-py3-none-any.whl (9.3 kB view details)

Uploaded Python 3

File details

Details for the file mdformat_space_control-0.1.3.tar.gz.

File metadata

  • Download URL: mdformat_space_control-0.1.3.tar.gz
  • Upload date:
  • Size: 20.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.32.5

File hashes

Hashes for mdformat_space_control-0.1.3.tar.gz
Algorithm Hash digest
SHA256 dc9da40068b6a0ec9a0f0b40df703985bab0b00f2439b1cd48ec04e4c735e0c6
MD5 2a10e136f7ce94750cfe4dcb4b1fde74
BLAKE2b-256 e03955b41b2771c24090d8704f47257413fcf9cee4eb87d71c495bf5e39e7894

See more details on using hashes here.

File details

Details for the file mdformat_space_control-0.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for mdformat_space_control-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 7d8590522d4ec014e18d27715be92c86d69fd80ca4c507d572d03e50bde807bb
MD5 664e648b4d87f0e51f890e8f672410dc
BLAKE2b-256 ff6fbd79910a0efedcac022c58eccbd11c8a2558299f73a1bec5411b90915168

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