Expand description
Modular rulesets for mdbook-lint
This crate provides comprehensive markdown linting rules for mdBook projects and general markdown files. Rules are organized into two main categories, each available as an optional feature.
§Overview
The mdbook-lint-rulesets
crate implements the actual linting rules used by mdbook-lint.
It provides:
- 59 standard markdown rules (MD001-MD059) based on the markdownlint specification
- 7 mdBook-specific rules (MDBOOK001-MDBOOK007) for mdBook project validation
- Automatic fix support for many rules to correct issues automatically
- Configurable rules with sensible defaults
§Features
standard
(default): Standard markdown linting rulesmdbook
(default): mdBook-specific linting rules
§Rule Categories
§Standard Markdown Rules (MD001-MD059)
These rules cover common markdown style and formatting issues:
- Heading rules (MD001-MD003, MD018-MD025): Heading hierarchy, style, and formatting
- List rules (MD004-MD007, MD029-MD032): List formatting, indentation, and consistency
- Whitespace rules (MD009-MD012, MD027-MD028): Trailing spaces, blank lines, tabs
- Link rules (MD034, MD039, MD042): URL formatting and link text
- Code rules (MD038, MD040, MD046, MD048): Code block formatting and fencing
- Emphasis rules (MD036-MD037, MD049-MD050): Bold and italic formatting
§mdBook-Specific Rules (MDBOOK001-MDBOOK007)
These rules validate mdBook-specific requirements:
- MDBOOK001: Code blocks should have language tags
- MDBOOK002: SUMMARY.md should follow mdBook structure
- MDBOOK003: Internal links should be valid
- MDBOOK004: Part titles should be formatted correctly
- MDBOOK005: Chapter paths should be relative
- MDBOOK006: Draft chapters should have content or be marked
- MDBOOK007: Separator syntax should be correct
§Usage
§Basic Setup
use mdbook_lint_rulesets::{StandardRuleProvider, MdBookRuleProvider};
use mdbook_lint_core::PluginRegistry;
let mut registry = PluginRegistry::new();
// Register standard markdown rules
registry.register_provider(Box::new(StandardRuleProvider))?;
// Register mdBook-specific rules
registry.register_provider(Box::new(MdBookRuleProvider))?;
§Using with the Lint Engine
use mdbook_lint_core::{PluginRegistry, Document};
use mdbook_lint_rulesets::StandardRuleProvider;
use std::path::PathBuf;
// Create registry and register provider
let mut registry = PluginRegistry::new();
registry.register_provider(Box::new(StandardRuleProvider))?;
// Create engine with registered rules
let engine = registry.create_engine()?;
// Lint a document
let content = "# My Document\n\n## Section\n";
let doc = Document::new(content.to_string(), PathBuf::from("README.md"))?;
let violations = engine.lint_document(&doc)?;
§Automatic Fixes
Many rules support automatic fixing of violations. Rules with fix support include:
- MD009: Remove trailing spaces
- MD010: Replace hard tabs with spaces
- MD012: Remove multiple consecutive blank lines
- MD018: Add space after hash in ATX headings
- MD019: Fix multiple spaces after hash
- MD020: Remove spaces inside closed ATX headings
- MD021: Fix multiple spaces inside closed ATX headings
- MD023: Remove indentation from headings
- MD027: Fix multiple spaces after blockquote symbol
- MD030: Fix spaces after list markers
- MD034: Wrap bare URLs in angle brackets
- MD047: Ensure files end with single newline
§Configuration
Rules can be configured through the RuleConfig
trait. Example configuration:
[rules.MD013]
line_length = 120
code_blocks = false
[rules.MD009]
br_spaces = 2
strict = false
Re-exports§
pub use standard::StandardRuleProvider;
pub use mdbook::MdBookRuleProvider;
Modules§
- mdbook
- mdBook-specific linting rules (MDBOOK001-007)
- standard
- Standard markdown linting rules (MD001-MD059)
Structs§
- Document
- Represents a parsed markdown document with position information
- Rule
Metadata - Metadata about a rule’s status, category, and properties
- Rule
Registry - Registry for managing linting rules
- Violation
- A violation found during linting
Enums§
- Rule
Category - Rule categories for grouping and filtering
- Rule
Stability - Rule stability levels
Traits§
- Rule
- Trait that all linting rules must implement
- Rule
Provider - Trait for rule providers to register rules with the engine
Type Aliases§
- Result
- Result type alias for mdbook-lint operations