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.
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).
If you prefer a one-liner installer that picks the right release artifact for your platform, you can use the installer scripts below. These scripts download from this repository's latest GitHub release and install to a user-local directory by default. If you prefer, download and inspect the script before running it.
For macOS and Linux:
|
For Windows PowerShell:
powershell -NoProfile -ExecutionPolicy Bypass -Command "irm https://github.com/jolars/panache/releases/latest/download/panache-installer.ps1 | iex"
Arch Linux
There are also two recipies available for Arch Linux in the AUR:
panache and
panache-bin.
The first builds from source for your system, the second uses precompiled binaries attatched to GH releases.
Install either using yay or your favorite AUR helper:
NixOS
Panache is available in NixOS via the panache package in nixpkgs. To add it
to your system configuration, include it in the environment.systemPackages:
{ pkgs, ... }:
{
environment.systemPackages = [
pkgs.panache
];
}
VS Code Extension
If you are running VS Code or an editor that supports VS Code extensions (like
Positron), you can install the Panache
extension
from the VS Code Marketplace or the Open VSX
extension, which will
automatically also install the panache CLI and start the language server when
editing supported files.
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.
Integrations
GitHub Actions
For CI, use the dedicated GitHub Action:
- uses: jolars/panache-action@v1
See the Integrations documentation for configuration options.
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 and Scope
- Full LSP implementation with formatting, diagnostics, code actions, and more
- Standalone CLI for both formatting and linting
- Support for Quarto, Pandoc, and R Markdown syntax
- Lossless CST-based parsing
- Idempotent formatting
- Semi-opinionated defaults with configurable style options for common formatting decisions
- Support for running external formatters and linters on code blocks, with built-in presets for popular languages and tools
Acknowledgements
The development of Panache has simplified considerably thanks to the extensive documentation, well-structured code, and testing infrastructure provided by Pandoc. We also owe significant debt to the rust-analyzer project, on which Panche is heavily inspired.