Please check the build logs for more information.
See Builds for ideas on how to fix a failed build, or Metadata for how to configure docs.rs builds.
If you believe this is docs.rs' fault, open an issue.
Panache
A language server, formatter, and linter for Pandoc, Quarto, and R Markdown.
Work in Progress
This project is in early development. Expect bugs, missing features, and breaking changes.
Installation
From crates.io
If you have Rust installed, the easiest way is likely to install from crates.io:
Pre-built Binaries
Alternatively, you can install pre-built binary packages from the releases
page for Linux, macOS, and Windows.
For Linux, packages are available for generic distributions (tarballs) as well
as Debian/Ubuntu (.deb) and Fedora/RHEL/openSUSE (.rpm).
Usage
Panache provides a single CLI interface for formatting, linting, and running the LSP server.
Formatting
To format a file in place, simply run:
You can also format from stdin by piping content into panache format:
|
panache format supports glob patterns and recursive directory formatting:
You can use Panache as a linter via the --check flag to check if files are
already formatted without making changes:
External Code Formatters
Panache supports external formatters for code blocks. For example, you can
configure it to run air on R code blocks and ruff on Python code blocks:
[]
= "air"
= "ruff"
= "prettier"
= "prettier" # Reuse same formatter
You can setup custom formatters or modify built-in presets with additional arguments:
[]
= ["isort", "black"]
= "foobar"
[]
= ["--profile=black"]
[]
= "foobar"
= ["--print-width=100"]
= true
Linting
Panache also features a linter that can report formatting issues and optionally auto-fix them. To run the linter, use:
As with panache format, you can use glob patterns and recursive formatting:
External Linters
As with formatting, Panache supports external linters for code blocks. These
are configured in the [linters] section of the configuration, but due to the
complexity of linting, including dealing with auto-fixing, external linters
cannot be customized and only support presets and at the moment only support R
via the jarl linter:
# Enable R linting
[]
= "jarl" # R linter with JSON output
Language Server
Panache implements the language server protocol (LSP) to provide editor features like formatting, diagnostics, code actions, and more.
To start the language server, run:
Most users will want to configure their editor to start the language server automatically when editing. See the language server documentation for guides on configuring your editor. For VS Code and related editors such as Positron, there is a VS Code Marketplace extension and Open VSX extension that provides an LSP client and additional features.
The server communicates over stdin/stdout and provides document formatting
capabilities. For Quarto projects, the LSP also reads _quarto.yml,
per-directory _metadata.yml, and metadata-files includes to supply
project-level metadata to bibliography-aware features. For Bookdown,
_bookdown.yml, _output.yml, and index.Rmd frontmatter are also considered.
The list of LSP features supported by Panache includes, among others:
- Document formatting (full document, incremental and range)
- Diagnostics with quick fixes
- Code actions for refactoring
- Convert between loose/compact lists
- Convert between inline/reference footnotes
- Document symbols/outline
- Folding ranges
- Go to definition for references and footnotes
Configuration
Panache looks for a configuration in:
.panache.tomlorpanache.tomlin current directory or parent directories$XDG_CONFIG_HOME/panache/config.toml(usually~/.config/panache/config.toml)
Example
# Markdown flavor and line width
= "quarto"
= 80
= "auto"
# Formatting style
[]
= "reflow"
# External code formatters (opt-in)
[]
= ["isort", "black"] # Sequential formatting
= "air" # Built-in preset
= "prettier" # Reusable definitions
= "prettier"
= "yamlfmt" # Formats both code blocks AND frontmatter
# Customize formatters
[]
= ["--print-width=100"]
# External code linters
[]
= "jarl" # Enable R linting
See .panache.toml.example for a complete configuration reference.
Pre-commit Hooks
Panache integrates with pre-commit to automatically format and lint your files before committing.
Installation:
First, install pre-commit if you haven't already:
# or
Then add Panache to your .pre-commit-config.yaml:
repos:
- repo: https://github.com/jolars/panache
rev: v2.16.0 # Use the latest version
hooks:
- id: panache-format # Format files
- id: panache-lint # Lint and auto-fix issues
Install the hooks:
Panache will now automatically run on your staged .qmd, .md, and .Rmd
files before each commit.
See examples/pre-commit-config.yaml for more configuration options.
Motivation
I wanted a formatter that understands Quarto and Pandoc syntax. I have tried to use Prettier as well as mdformat, but both fail to handle some of the particular syntax used in Quarto documents, such as fenced divs and some of the table syntax.
Design Goals
- Full LSP implementation for editor integration
- Linting as part of LSP but also available as a standalone CLI command
- Support Quarto, Pandoc, and Markdown syntax
- Fast lossless parsing and formatting (no CST changes if already formatted)
- Be configurable, but have sane defaults (that most people can agree on)
- Format math
- Hook into external formatters for code blocks (e.g.
airfor R,rufffor Python)