15 个版本

0.2.2 2024 年 8 月 6 日
0.2.1 2024 年 6 月 28 日
0.1.2 2024 年 6 月 20 日
0.0.8 2024 年 6 月 6 日
0.0.1 2024 年 3 月 19 日

#213开发工具

Download history • Rust 包仓库 168/week @ 2024-05-20 • Rust 包仓库 129/week @ 2024-05-27 • Rust 包仓库 256/week @ 2024-06-03 • Rust 包仓库 406/week @ 2024-06-10 • Rust 包仓库 185/week @ 2024-06-17 • Rust 包仓库 367/week @ 2024-06-24 • Rust 包仓库 183/week @ 2024-07-01 • Rust 包仓库 25/week @ 2024-07-08 • Rust 包仓库 6/week @ 2024-07-15 • Rust 包仓库 5/week @ 2024-07-22 • Rust 包仓库 84/week @ 2024-07-29 • Rust 包仓库 152/week @ 2024-08-05 • Rust 包仓库 31/week @ 2024-08-12 • Rust 包仓库

273 每月下载量

MIT 许可证

355KB
10K SLoC

mdsf

使用您喜欢的代码格式化工具格式化 Markdown 代码片段。

mdsf 0.2.2
Format markdown code snippets using your favorite code formatters
Mads Hougesen <mads@mhouge.dk>

Usage: mdsf <COMMAND>

Commands:
  format       Run formatters on input files
  verify       Verify files are formatted
  init         Create a new mdsf config
  completions  Generate shell completion
  cache-prune  Remove old caches
  help         Print this message or the help of the given subcommand(s)

Options:
  -h, --help     Print help
  -V, --version  Print version

安装

您可以从 github.com/hougesen/mdsf/releases 直接下载最新版本的 mdsf

Cargo

使用已发布的 crates 安装

cargo install mdsf --locked

或直接从源代码安装

git clone git@github.com:hougesen/mdsf.git

cargo install --path ./mdsf --bin mdsf

用法

mdsf format <NAME_OF_FOLDER_OR_FOLDER>
Run formatters on input files

Usage: mdsf format [OPTIONS] <PATH>

Arguments:
  <PATH>  Path to file or directory

Options:
      --config <CONFIG>        Path to config
      --debug                  Log stdout and stderr of formatters
      --log-level <LOG_LEVEL>  [possible values: trace, debug, info, warn, error, off]
      --threads <THREADS>      Amount of threads to use. Defaults to 0 (auto)
      --cache                  Only format changed codeblocks
  -h, --help                   Print help
  -V, --version                Print version

验证代码是否已格式化

mdsf verify <NAME_OF_FOLDER_OR_FOLDER>
Verify files are formatted

Usage: mdsf verify [OPTIONS] <PATH>

Arguments:
  <PATH>  Path to file or directory

Options:
      --config <CONFIG>        Path to config
      --debug                  Log stdout and stderr of formatters
      --log-level <LOG_LEVEL>  [possible values: trace, debug, info, warn, error, off]
      --threads <THREADS>      Amount of threads to use. Defaults to 0 (auto)
  -h, --help                   Print help
  -V, --version                Print version

配置

mdsf 的默认配置旨在尽可能合理。因此,每种语言的默认格式化程序是大多数人已经安装的格式化程序。

如果您想自定义要运行的格式化程序,可以运行以下命令创建一个新的 mdsf 配置文件

mdsf init

mdsf 支持在相同的代码片段上运行多个格式化程序。

{
  // Only run `ruff` on Python snippets,
  "python": "ruff",
  // Run `usort` on file and then `black`
  "python": ["usort", "black"],
  // Run `usort`, if that fails run `isort`, finally run `black`
  "python": [["usort", "isort"], "black"]
}

支持的工具

[!NOTE] mdsf 不是一个包管理器。

只有已安装的工具将被使用。

mdsf 目前支持 174 个工具。如果您喜欢的工具缺失,请随时提交 issue/pull-request! 😃

格式化程序 描述
alejandra https://github.com/kamadorueda/alejandra
ameba https://github.com/crystal-ameba/ameba
asmfmt https://github.com/klauspost/asmfmt
astyle https://astyle.sourceforge.net
auto-optional https://pypi.ac.cn/project/auto-optional/
autocorrect https://github.com/huacnlee/autocorrect
autoflake https://github.com/pycqa/autoflake
autopep8 https://pypi.ac.cn/project/autopep8/
beautysh https://pypi.ac.cn/project/beautysh/
bicep_format https://github.com/Azure/bicep
biome https://biomejs.dev
biome_check https://biomejs.dev
biome_lint https://biomejs.dev
black https://github.com/psf/black
blade-formatter https://github.com/shufo/blade-formatter
blue https://blue.readthedocs.io/en/latest/
bpfmt https://source.android.com/docs/setup/reference/androidbp
brittany https://github.com/lspitzner/brittany
bsfmt https://github.com/rokucommunity/brighterscript-formatter
buf https://buf.build/docs/reference/cli/buf/format
buildifier https://github.com/bazelbuild/buildtools
cabal_format https://www.haskell.org/cabal/
caramel_fmt https://caramel.run
clang-format https://docs.linuxkernel.org.cn/process/clang-format.html
clang-tidy https://clang.llvm.net.cn/extra/clang-tidy
cljstyle https://github.com/greglook/cljstyle
codespell https://github.com/codespell-project/codespell
crlfmt https://github.com/cockroachdb/crlfmt
crystal_format https://crystal.ruby-lang.org.cn/
csharpier https://csharpier.com/
css-beautify https://github.com/beautifier/js-beautify
csscomb https://github.com/csscomb/csscomb.js
d2 https://d2lang.com/
dart_fix https://dart.ac.cn/tools/dart-fix
dart_format https://dart.ac.cn/tools/dart-format
dcm_fix https://dcm.dev/docs/cli/fix/
dcm_format https://dcm.dev/docs/cli/format/
deno_fmt https://docs.deno.org.cn/runtime/manual/tools/formatter
deno_lint https://docs.deno.org.cn/runtime/manual/tools/linter
dfmt https://github.com/dlang-community/dfmt
dhall https://dhall-lang.org/
djlint https://www.djlint.com/
docformatter https://pypi.ac.cn/project/docformatter/
docstrfmt https://pypi.ac.cn/project/docstrfmt/
dotenv-linter https://github.com/dotenv-linter/dotenv-linter
dprint https://dprint.dev
easy-cofing-standard https://github.com/easy-coding-standard/easy-coding-standard
efmt https://github.com/sile/efmt
elm-format https://github.com/avh4/elm-format
erb-formatter https://github.com/nebulab/erb-formatter
erlfmt https://github.com/WhatsApp/erlfmt
eslint https://eslint.org.cn
fantomas https://github.com/fsprojects/fantomas
findent https://pypi.ac.cn/project/findent/
fish_indent https://fishshell.com/docs/current/cmds/fish_indent.html
fixjson https://github.com/rhysd/fixjson
floskell https://github.com/ennocramer/floskell
fnlfmt https://git.sr.ht/~technomancy/fnlfmt
forge_fmt https://docs.rs/forge-fmt/latest/forge_fmt/
fourmolu https://hackage.haskell.org/package/fourmolu
fprettify https://github.com/fortran-lang/fprettify
gci https://github.com/daixiang0/gci
gdformat https://github.com/scony/godot-gdscript-toolkit
gersemi https://github.com/blankspruce/gersemi
gleam_format https://gleam.run/
gluon_fmt https://github.com/gluon-lang/gluon
gofmt https://pkg.go.dev/cmd/gofmt
gofumpt https://github.com/mvdan/gofumpt
goimports https://pkg.go.dev/golang.org/x/tools/cmd/goimports
goimports-reviser https://github.com/incu6us/goimports-reviser
golines https://github.com/segmentio/golines
google-java-format https://github.com/google/google-java-format
grain_format https://grain-lang.org
haml-lint https://github.com/sds/haml-lint
hfmt https://github.com/danstiner/hfmt
hindent https://hackage.haskell.org/package/hindent
html-beautify https://github.com/beautifier/js-beautify
htmlbeautifier https://github.com/threedaymonk/htmlbeautifier
imba_fmt https://github.com/imba/imba
isort https://pycqa.github.io/isort/
joker https://github.com/candid82/joker
js-beautify https://github.com/beautifier/js-beautify
jsona_format https://github.com/jsona/jsona
jsonnetfmt https://jsonnet.org/learning/tools.html
juliaformatter.jl https://github.com/domluna/JuliaFormatter.jl
just_fmt https://github.com/casey/just
kcl_fmt https://www.kcl-lang.io/docs/tools/cli/kcl/fmt
kdlfmt https://github.com/hougesen/kdlfmt
ktfmt https://github.com/facebook/ktfmt
ktlint https://github.com/pinterest/ktlint
leptosfmt https://github.com/bram209/leptosfmt
liquidsoap-prettier https://github.com/savonet/liquidsoap-prettier
luaformatter https://github.com/Koihik/LuaFormatter
markdownlint https://github.com/davidanson/markdownlint
markuplint https://markuplint.dev
mdformat https://github.com/executablebooks/mdformat
misspell https://github.com/client9/misspell/
mix_format https://hexdocs.cn/mix/main/Mix.Tasks.Format.html
nickel_format https://nickel-lang.org
nimpretty https://github.com/nim-lang/nim
nixfmt https://github.com/serokell/nixfmt
nixpkgs-fmt https://github.com/nix-community/nixpkgs-fmt
nph https://github.com/arnetheduck/nph
npm-groovy-lint https://github.com/nvuillam/npm-groovy-lint
ocamlformat https://github.com/ocaml-ppx/ocamlformat
ocp-indent https://github.com/OCamlPro/ocp-indent
ormolu https://hackage.haskell.org/package/ormolu
oxlint https://oxc.npmjs.net.cn
packer_fmt https://developer.hashicorp.com/packer/docs/commands/fmt
perltidy https://github.com/perltidy/perltidy
pg_format https://github.com/darold/pgFormatter
php-cs-fixer https://github.com/PHP-CS-Fixer/PHP-CS-Fixer
phpcbf https://phpqa.io/projects/phpcbf.html
phpinsights https://phpinsights.com/
pint https://github.com/laravel/pint
prettier https://github.com/prettier/prettier
pretty-php https://github.com/lkrms/pretty-php
prisma https://prisma.org.cn/
puppet-lint https://github.com/puppetlabs/puppet-lint
purs-tidy https://github.com/natefaubion/purescript-tidy
pycln https://github.com/hadialqattan/pycln
pyink https://github.com/google/pyink
qmlfmt https://github.com/jesperhh/qmlfmt
raco_fmt https://docs.racket-lang.org/fmt/
refmt https://reasonml.github.io/docs/en/
rescript_format https://rescript-lang.org/
roc_format https://github.com/roc-lang/roc
rstfmt https://github.com/dzhu/rstfmt
rubocop https://github.com/rubocop/rubocop
rubyfmt https://github.com/fables-tales/rubyfmt
ruff https://docs.astral.sh/ruff/formatter/
ruff_check https://docs.astral.sh/ruff/linter/
rufo https://github.com/ruby-formatter/rufo
rune_fmt https://github.com/rune-rs/rune
rustfmt https://github.com/rust-lang/rustfmt
rustywind https://github.com/avencera/rustywind
scalafmt https://github.com/scalameta/scalafmt
shfmt https://github.com/mvdan/sh
sleek https://github.com/nrempel/sleek
smlfmt https://github.com/shwestrick/smlfmt
snakefmt https://github.com/snakemake/snakefmt
sql-formatter https://github.com/sql-formatter-org/sql-formatter
sqlfluff https://github.com/sqlfluff/sqlfluff
sqlfmt https://sqlfmt.com
standardjs https://standardjs.com/
standardrb https://github.com/standardrb/standard
stylefmt https://github.com/matype/stylefmt
stylelint https://github.com/stylelint/stylelint
stylish-haskell https://github.com/haskell/stylish-haskell
stylua https://github.com/JohnnyMorganz/StyLua
swift-format https://github.com/apple/swift-format
swiftformat https://github.com/nicklockwood/SwiftFormat
taplo https://github.com/tamasfe/taplo
templ https://templ.guide
terraform_fmt https://www.terraform.io/docs/cli/commands/fmt.html
tlint https://github.com/tighten/tlint
tofu_fmt https://opentofu.org.cn/docs/cli/commands/fmt/
topiary https://github.com/tweag/topiary
ts-standard https://github.com/standard/ts-standard
twig-cs-fixer https://github.com/VincentLanglet/Twig-CS-Fixer
typos https://github.com/crate-ci/typos
uiua_fmt https://github.com/uiua-lang/uiua
usort https://github.com/facebook/usort
veryl_fmt https://github.com/veryl-lang/veryl
vlang_fmt https://vlang.io
xmlformat https://github.com/pamoller/xmlformatter
xmllint http://xmlsoft.org/xmllint.html
xo http://github.com/xojs/xo
yamlfix https://github.com/lyz-code/yamlfix
yamlfmt https://github.com/google/yamlfmt
yapf https://github.com/google/yapf
yew-fmt https://github.com/its-the-shrimp/yew-fmt
zigfmt https://ziglang.org/
zprint https://github.com/kkinnear/zprint

Shell completions

可以使用以下命令生成 Shell 完整性:mdsf completions <SHELL>

Generate shell completion

Usage: mdsf completions <SHELL>

Arguments:
  <SHELL>  [possible values: bash, elvish, fish, powershell, zsh]

Options:
  -h, --help     Print help
  -V, --version  Print version

Bash

将以下内容添加到您的 .bashrc

eval "$(mdsf completions bash)"

Bash

将以下内容添加到您的 .zshrc

eval "$(mdsf completions zsh)"

Fish

将以下内容添加到 ~/.config/fish/config.fish

mdsf completions fish | source

PowerShell

将以下内容添加到您的PowerShell配置文件中(可以通过运行 $PROFILE 来找到)。

Invoke-Expression (&mdsf completions powershell)

Elvish

将以下内容添加到 ~/.elvish/rc.elv

eval (mdsf completions elvish)

致谢

mdsf 受益于惊人的 neovim 格式化插件 conform.nvim

mdsf 的替代方案

依赖项

~8–20MB
~280K SLoC