From 33d4b0fd21c4290f9f7c825d0efc737f502999b5 Mon Sep 17 00:00:00 2001 From: William G Underwood <42812654+WGUNDERWOOD@users.noreply.github.com> Date: Thu, 2 May 2024 11:40:33 -0400 Subject: [PATCH] Update performance information in README --- README.md | 40 ++++++++++++++++++---------------------- notes.org | 3 --- perf.sh | 3 ++- 3 files changed, 20 insertions(+), 26 deletions(-) diff --git a/README.md b/README.md index 69eaaf6..34f58f0 100644 --- a/README.md +++ b/README.md @@ -56,6 +56,11 @@ E = m c^2 +- ⚡ Very good run-time performance +- 🔧 No configuration necessary +- 📟 Command-line interface +- 📜 Handles LaTeX file types `.tex`, `.bib`, `.cls`, and `.sty` + ## Installation ### Nix @@ -69,34 +74,25 @@ nix build "github:wgunderwood/tex-fmt" ``` shell cargo install --git "https://github.com/wgunderwood/tex-fmt" ``` -## Aims - -This project aims to provide a command-line tool for formatting -LaTeX source code files with the following properties: - -- Handling of the common LaTeX file types `.tex`, `.bib`, `.cls`, and `.sty` -- Very good run-time performance -- No configuration necessary - -It does *not* currently aim to provide the following: - -- Semantic parsing of LaTeX code -- Linting or correction of syntax errors -- Customization via configuration files -- Compliance with existing formatting guidelines -- Editor integration -- Spell checking - ## Performance -Run `perf.sh` to format all test cases in the `tests/` directory. -For larger files, tex-fmt is hundreds of times faster than latexindent. +Run `perf.sh` to format all test cases. +For large files, tex-fmt is hundreds of times faster than latexindent. | **Files** | **Lines** | **Size** | **tex-fmt** | **latexindent** | **latexindent -m** | | --- | --- | --- | --- | --- | --- | -| 6 | 30k | 900kb | **0.0362s** | 11.6s [x322] | 15.3s [x424] | +| 11 | 30k | 800kb | **0.0362s** | 12.0s [x333] | 15.9s [x439] | + +## Limitations + +- Semantic parsing of LaTeX code not conducted +- No linting or correction of syntax errors +- Customization via configuration files not supported +- Compliance with existing formatting guidelines not guaranteed +- Editor integration not currently provided +- No spell checking -## Comparison with existing tools +## Existing tools - [latexindent](https://github.com/cmhughes/latexindent.pl). Perl script, many configuration options, slow on large files. diff --git a/notes.org b/notes.org index 356f736..73e2797 100644 --- a/notes.org +++ b/notes.org @@ -2,9 +2,6 @@ * Tests ** Look for problem cases in other latex documents * Features -** TODO Environments should start and end on new lines -*** New line before begin/end with regex replace -*** Care with comments ** Fold long lines to 80 characters *** Care with trailing comments *** No folding in verbatim environments, just warn diff --git a/perf.sh b/perf.sh index 4c4fa53..41de084 100644 --- a/perf.sh +++ b/perf.sh @@ -7,7 +7,8 @@ for f in $DIR/*.tex; do echo -n "$(wc -l $f | cut --delimiter=" " --fields 1) lines, " echo "$(ls -sh $f | cut --delimiter=" " --fields 1)" done -echo -n "Total: $(wc -l --total=only $DIR/*.tex) lines, " +echo -n "Total: $(ls -l $DIR/*.tex | wc -l) files, " +echo -n "$(wc -l --total=only $DIR/*.tex) lines, " echo "$(ls -lh $DIR | head -n 1 | cut --delimiter=" " --fields 2)" echo