# Changes ## expltools 2025-03-27 ### explcheck v0.8.0 #### Development - Add syntactic analysis. (#66) - Add Lua option `verbose` and a command-line option `--verbose` that prints extra information in human-readable output. (#66) For example, here is the output of processing the files `markdown.tex` and `markdownthemewitiko_markdown_defaults.sty` of the Markdown package for TeX with TeX Live 2024: ``` $ explcheck --verbose `kpsewhich markdown.tex markdownthemewitiko_markdown_defaults.sty` ``` ``` Checking 2 files Checking /usr/local/texlive/2024/texmf-dist/tex/generic/markdown/markdown.tex OK File size: 103,972 bytes Preprocessing results: - Doesn't seem like a LaTeX style file - Six expl3 parts spanning 97,657 bytes (94% of file): 1. Between 48:14 and 620:11 2. Between 637:14 and 788:4 3. Between 791:14 and 2104:8 4. Between 2108:14 and 3398:4 5. Between 3413:14 and 4210:4 6. Between 4287:14 and 4444:4 Lexical analysis results: - 19,344 TeX tokens in expl3 parts Syntactic analysis results: - 645 top-level expl3 calls spanning all tokens Checking /.../tex/latex/markdown/markdownthemewitiko_markdown_defaults.sty OK File size: 34,894 bytes Preprocessing results: - Seems like a LaTeX style file - Seven expl3 parts spanning 18,515 bytes (53% of file): 1. Between 47:14 and 349:4 2. Between 382:14 and 431:2 3. Between 446:14 and 512:4 4. Between 523:14 and 564:2 5. Between 865:14 and 931:2 6. Between 969:14 and 1003:2 7. Between 1072:14 and 1328:2 Lexical analysis results: - 3,848 TeX tokens in expl3 parts Syntactic analysis results: - 69 top-level expl3 calls spanning 2,082 tokens (54% of tokens, ~29% of file) Total: 0 errors, 0 warnings in 2 files Aggregate statistics: - 138,866 total bytes - 116,172 expl3 bytes (84% of files) containing 23,192 TeX tokens - 714 top-level expl3 calls spanning 21,426 tokens (92% of tokens, ~77% of files) ``` - Add Lua option `terminal_width` that determines the layout of the human-readable command-line output. (#66) - Stabilize the Lua API of processing steps. (#64) All processing steps are now functions that accept the following arguments: 1. The filename of a processed file 2. The content of the processed file 3. A registry of issues with the processed file (write-only) 4. Intermediate analysis results (read-write) 5. Options (read-only, optional) #### Fixes - During preprocessing, only consider standard delimiters of expl3 parts that are either not indented or not in braces. (discussed in #17, fixed in #66) - During preprocessing, support `\endinput`, `\tex_endinput:D`, and `\file_input_stop:` as standard delimiters of expl3 parts. (#66) - During preprocessing, do not produce warning W101 (Unexpected delimiters) for a `\ProvidesExpl*` after `\ExplSyntaxOn`. (#66) - Prevent newlines from being recognized as catcode 15 (invalid) with Lua 5.2 due to unreliable order of table keys. (#66) #### Continuous integration - Add regression tests for TeX Live 2024. (#66) - Configure Dependabot version updates for GitHub Actions. (contributed by @koppor in #70) ## expltools 2025-02-25 ### explcheck v0.7.1 #### Development - Add support for config file sections `[package.…]` for specifying package-specific configuration. (#32, #57, #62, #63) For example, here is how you might configure the file `expl3-code.tex` from the package `l3kernel` in your configuration file `.explcheckrc`: ``` toml [package.l3kernel] expl3_detection_strategy = "always" ignored_issues = ["w200", "w202", "e208", "e209"] max_line_length = 140 ``` - Add value `"never"` for the command-line option `--expl3-detection-strategy` and the Lua option `expl3_detection_strategy`. (#63) - Pre-configure all remaining expl3 files from current TeX Live with more than 1 error in . (#32, #57, #62, #63, 4bf5597e, d074dbef) ## expltools 2025-02-24 ### explcheck v0.7.0 #### Development - Generate a static web site for the exploration of issues in all expl3 files from TeX Live. (discussed with @norbusan and @koppor in #28 and #32, implemented in by @koppor) The web side is available here: . - Add support for config file sections `[filename."…"]` for specifying file-specific configuration. (#32, #57, #62) For example, here is how you might configure a file `expl3-code.tex` from your configuration file `.explcheckrc`: ``` toml [filename."expl3-code.tex"] expl3_detection_strategy = "always" ignored_issues = ["w200", "w202", "e208", "e209"] max_line_length = 140 ``` - Pre-configure well-known files from current TeX Live with more than 100 error detections in . (#32, #57, #62) - Add command-line option `--error-format` and Lua option `error_format`. (discussed with @koppor in koppor/errorformat-to-html#2, added in #40, 5034639, and #43) This allows users to specify Vim's quickfix errorformat used for the machine-readable output when the command-line option `--porcelain` or the Lua option `porcelain` is enabled. - Add command-line option `--expl3-detection-strategy` and Lua option `expl3_detection_strategy`. (drafted and discussed with @koppor in #38, added in #49) - Add command-line option `--make-at-letter` and Lua option `make_at_letter`. (discussed with @zepinglee in #30 and #36, added in #61) These options determine how the at sign (`@`) should be tokenized. The default value `"auto"` automatically determines the category code based on context cues. #### Fixes - Prevent false positive E102 (Unknown argument specifiers) detections for control sequences with multiple colons (`::`). (#62) - Ensure that whole files are considered to be in expl3 when the Lua option `expl3_detection_strategy` is set to `"always"`, even when the files contain standard delimiters `\ProvidesExpl*`. (#62) This also prevents false positive E102 (expl3 material in non-expl3 parts) detections. - Only report warning S103 (Line too long) in expl3 parts. (#38, #49) - In machine-readable output, report the line and column number 1 for file-wide issues. (reported by @koppor in #39, fixed in #40) - Exclude comments from maximum line length checks. (reported by @muzimuzhi in #27, fixed in #43, #58, and #59) This includes spaces before the comments. - Always accept both lower- and upper-case issue identifiers. (reported by @muzimuzhi in #26, fixed in #44) This includes Lua options and configuration files, in addition to command-line options and inline TeX comments. - Exclude "weird" argument specifiers (`:w`) from warning W200. (reported by @muzimuzhi in #25, fixed in #45) - Remove error E203 (Removed control sequences). (reported by @koppor in #53, fixed in #54) - Fix two instances of explcheck crashing while processing input files. (reported by @koppor in #31, fixed in #52 and #59) - Do not recognize `@` as a part of an expl3 control sequence. (reported by @zepinglee in #30 and #37, fixed in #60) This prevents warnings S205 and S206 for LaTeX2e control sequence (re)definitions. #### Deprecation - Deprecate the command-line option `--expect-expl3-everywhere` and remove the Lua option `expect_expl3_everywhere`. (#49) Use the command-line option `--expl3-detection-strategy=always` or the corresponding Lua option `expl3_detection_stragegy = "always"` instead. - Deprecate the default config file section `[options]`. (#62) Rename the section to `[defaults]` instead. #### Documentation - Add SPDX license identifier to `README.md`. (added by @koppor in #50) - Link a list of all currently supported issues from `README.md`. (added by @koppor in #51) - Link from `README.md`. (#28, #32, b774ba77) #### Continuous integration - Continuously run explcheck on all packages in historical TeX Live Docker images. (suggested by @hansonchar in #28 and #31, added in #52 and #56) - Use ShellCheck to check code style of Bash scripts. (#61) #### Housekeeping - Make off-by-one errors less likely when working with byte ranges. (#47, #48, 13ebfc6e, a0923d06) #### Artwork - Add artwork by https://www.quickcartoons.com/ to directory `artwork/`. (566769b) ## expltools 2025-01-20 ### explcheck v0.6.1 #### Fixes - Correctly read option `warnings_are_errors` from file `.explcheckrc`. (e351fdd) ## expltools 2025-01-16 ### explcheck v0.6.0 #### Development - Add support for TOML configuration files. (#24) You may configure the tool by placing a configuration file named `.explcheckrc` in the current working directory. For example, the following configuration file would increase the maximum line length before the warning S103 (Line too long) is produced from 80 to 120 characters and also disable the warnings W100 (No standard delimiters) and S204 (Missing stylistic whitespaces): ``` toml [options] max_line_length = 120 ignored_issues = ["w100", "s204"] ``` #### Fixes - Do not require lower-case identifiers in the command-line option `--ignored-issues`. (f394d38c) #### Distribution - Add Lua library `lfs` to Docker image `ghcr.io/witiko/expltools/explcheck`. (4f9f26f) This enables additional functionality, such as suggesting which `.ins` file the user should process with TeX to extract expl3 code from a `.dtx` archive. ## expltools 2025-01-15 ### explcheck v0.5.0 #### Development - Add support for ignoring file-wide issues and issues on a single line using TeX comments. (#23) For example, a comment `% noqa` will ignore any issues on the current line, whereas a comment `% noqa: W100, S204` will ignore the file-wide warning W100 (No standard delimiters) and the warning S204 (Missing stylistic whitespaces) on the current line. - Add command-line option `--ignored-issues` and Lua option `ignored_issues` for ignoring issues. (#23) For example, `--ignored-issues=w100,s204` will ignore the file-wide warning W100 (No standard delimiters) and all warnings S204 (Missing stylistic whitespaces). #### Fixes - Correctly shorten long names of files from the current working directory in the command-line output. (#23) - Correctly parenthesize and order LPEG parsers in the file `explcheck-obsolete.lua`. (#23) - Do not produce warning S204 (Missing stylistic whitespaces) for non-expl3, empty, or one-character names of control sequences. (#23) - Do not produce warning S204 (Missing stylistic whitespaces) for an empty grouping (`{}`). (#23) - Do not produce warning S204 (Missing stylistic whitespaces) for a parameter before begin grouping (`#1{`). (#23) - Do not produce S204 (Missing stylistic whitespaces) for a comma immediately after a control sequence. (505608f9) - Do not produce warnings S205 (Malformed function name) and S206 (Malformed variable or constant name) for non-expl3 functions, variables, and constants. (#23) - Do not produce warnings S206 (Malformed variable or constant name) for variable and constant names that contain names of built-in types such as `\c_module_constant_clist_tl` containing `clist`. (#23) ## expltools 2025-01-14 ### explcheck v0.4.0 #### Development - Add lexical analysis. (#21) #### Fixes - Do not detect error E102 (expl3 material in non-expl3 parts) when the command-line option `--expect-expl3-everywhere` has been specified. (#21) ## expltools 2024-12-23 ### explcheck v0.3.0 #### Development - Add option `--expect-expl3-everywhere` to ignore \ExplSyntaxOn and Off. (discussed with @muzimuzhi in #17, added in #19) - Add short-hand command-line option `-p` for `--porcelain`. (suggested by @FrankMittelbach in #8, added in #19) - Add file `explcheck-config.lua` with the default configuration of explcheck. (#19) You may place a file named `explcheck-config.lua` with your own configuration in your repository to control the behavior of explcheck. Note that the configuration options are provisional and may be changed or removed before version 1.0.0. Furthermore, support for configuration YAML files that will allow you to specify different configuration for different .tex files is envisioned for a future release and will be the recommended way to configure explcheck. #### Fixes - Make the detection of error E102 (expl3 material in non-expl3 parts) more precise. (discussed with @cfr42 in #18, fixed in #19) - Use a less naïve parser of TeX comments to improve the detection of issues W100 and E102. (reported by @FrankMittelbach in #8, fixed in #16) #### Documentation - State in the output of `explcheck --help` that command-line options are provisional and subject to change. (discussed with @FrankMittelbach and @muzimuzhi in #8 and #17, added in #19) - Display the default maximum line length in the output of `explcheck --help`. (#19) - Rename E102 to "expl3 material in non-expl3 parts". (discussed with @cfr42 in #18, added in #19) ## expltools 2024-12-13 ### explcheck v0.2.0 #### Development - Add a command-line option `--porcelain` for machine-readable output. (suggested by @FrankMittelbach in #8, added in #15) See and below for a demonstration of how you might set up your text editor, so that it automatically navigates you to lines with warnings and errors. #### Fixes - In the command-line interface, forbid the checking of .ins and .dtx files. Display messages that direct users to check the generated files instead. (reported by @josephwright and @FrankMittelbach in #8, fixed in #14) - Expect both backslashes and forward slashes when shortening pathnames. (#14) - Correctly pluralize "1 file" on the first line of command-line output. (#14) #### Documentation - Normalize the behavior and documentation of functions `get_*()` across files `explcheck/build.lua`, `explcheck/test.lua`, and `explcheck-cli.lua`. (#14) ## expltools 2024-12-09 ### explcheck v0.1.1 #### Fixes - In LuaTeX, initialize Kpathsea Lua module searchers first. (reported by @josephwright, Lars Madsen, and Philip Taylor on [tex-live@tug.org][tex-live-02] and by @muzimuzhi in #9, fixed on [tex-live@tug.org][tex-live-03] by @gucci-on-fleek) - Allow spaces between arguments of `\ProvidesExpl*` commands. (reported by @u-fischer and @josephwright in #7, fixed in #13) [tex-live-02]: https://tug.org/pipermail/tex-live/2024-December/050958.html [tex-live-03]: https://tug.org/pipermail/tex-live/2024-December/050968.html #### Documentation - Include explcheck version in the command-line interface. (reported in #10, fixed in #13) - Hint in the file `README.md` that .dtx files are not well-supported. (reported by @josephwright in #8, added in #13) - Show in the file `README.md` how explcheck can be used from Lua code. (#13) - Include instructions about using l3build in the file `README.md`. (reported in #11, added in #13) #### Continuous integration - Add `Dockerfile`, create Docker image, and mention it in the file `README.md`. (discussed in #12, added in #13) ## expltools 2024-12-04 ### explcheck v0.1 #### Development - Implement preprocessing. (#5) #### Documentation - Add `README.md`. (suggested by @Skillmon in #1, fixed in #2) - Update to Markdown 3. (#3) - Use the expl3 prefix `expltools`. (#3) - Add project proposal. (#4) #### Continuous integration - Use small Docker image. (#3) #### Distribution - Make changes to the CTAN archive following a discussion with TeX Live developers on [tex-live@tug.org][tex-live-01] and with CTAN maintainers. Many thanks specifically to Petra Rübe-Pugliese, Reinhard Kotucha, and Zdeněk Wagner. [tex-live-01]: https://tug.org/pipermail/tex-live/2024-December/050952.html