Releases: numtide/treefmt
v2.1.1
Bugfixes
- fixes a subtle concurrency bug which can cause
treefmt
to not exit with an error code if a formatter fails - fixes emojis and other non-ASCII characters in file paths 😂
Nixpkgs PR Tracker
https://nixpkgs-tracker.ocfox.me/?pr=360123
Changelog
- f8a1f44: README: fix coverage branch (@brianmcgee)
- d535b1d: README: new format (@zimbatm)
- e41339a: README: remove Rust to Go section (@brianmcgee)
- 3aaaf7c: README: remove golangci-lint workflow (@brianmcgee)
- 6698ee6: fix: bad links in README.md (@o-az)
- ab89e0b: fix: exiting with error if formatters fail (@brianmcgee)
- 887e9e9: fix: more bad links in README.md (@o-az)
- 91aef76: fix: non-ascii paths in git walker (@brianmcgee)
- a0be22d: fix: set go module to v2 (@brianmcgee)
- d5a39b0: fixup! fix: non-ascii paths in git walker (@brianmcgee)
v2.1.0
Better configuration
We replaced kong with cobra+viper for cli processing and configuration.
This brings two new features:
- Option overrides with environment variables.
- More options can now be configured in
treefmt.toml
.
The order of precedence between flags, env variables, and config is now also correct.
See here for more info.
Simpler codebase
Many improvements have been made to simplify the codebase and make it easier to follow.
In addition, we no longer rely on go-git; instead, we use git
itself.
We have seen some issues with go-git and decided that it wasn't adding much value and would always remain a source of discrepancy with git
itself.
Better testing
Thanks to jfly and their (sometimes excruciating 😜) attention to detail, we have fixed some bugs, refined some features, and improved the quality of testing overall.
Better documentation
It might not look as pretty as before, but we moved back to mkdocs-material.
The main driver for the change was a better story around versioning, which is being provided by mike.
Nixpkgs PR Tracker
https://nixpkgs-tracker.ocfox.me/?pr=354455
Changelog
- d7c1064: Avoid hanging: ensure we always close
f.filesCh
(@jfly) - e47674d: Clarify in the spec that the formatter MUST process the given files (@jfly)
- 962d695: ci: add mergify config (@brianmcgee)
- 94c53c5: ci: run golangci-lint as a flake check instead of github workflow (@brianmcgee)
- c131adc: feat: add connect timeout to bolt db (@brianmcgee)
- 45592a9: feat: add test helper for changing work directory (@brianmcgee)
- b834fa3: feat: best-effort application of files to formatters (@brianmcgee)
- 6bfe249: feat: bump golangci-lint version to 1.61.0 in github workflow (@brianmcgee)
- 6cadbbc: feat: create a separate docs devshell (@brianmcgee)
- b956dcd: feat: improve cache busting test (@brianmcgee)
- 9e45e55: feat: improve cache test (@brianmcgee)
- d7c39b6: feat: improve change detection (@brianmcgee)
- 9d9ea4e: feat: improve change working directory test (@brianmcgee)
- 500c356: feat: improve cpu profile test (@brianmcgee)
- 13849f2: feat: improve fail on change test (@brianmcgee)
- e32b5a2: feat: improve fail on change test (@brianmcgee)
- 782c7a0: feat: improve git test (@brianmcgee)
- 5659267: feat: improve missing formatter test (@brianmcgee)
- 57abb78: feat: improve paths handling (@brianmcgee)
- d0f5990: feat: improve prj root env test (@brianmcgee)
- 40e18a3: feat: improve specifying formatters test (@brianmcgee)
- 7a717ec: feat: improve unmatched test (@brianmcgee)
- 39774dc: feat: log treefmt command and output in tests (@brianmcgee)
- 71b262f: feat: match before checking cache (@brianmcgee)
- fc88f98: feat: more stringent golangci-lint rules (@brianmcgee)
- 21fbdc0: feat: refactor caching approach (@brianmcgee)
- ca655f5: feat: refactor processing (@brianmcgee)
- 66bdc82: feat: refine deterministic order test (@brianmcgee)
- 45ed5e8: feat: refine includes/excludes test (@brianmcgee)
- bda4138: feat: refine paths arg test (@brianmcgee)
- 41712b5: feat: refine run in subdir test (@brianmcgee)
- 9d53c96: feat: refine stdin test (@brianmcgee)
- 9fc9e67: feat: refine treefmt helper api in test (@brianmcgee)
- 9d521a9: feat: refine treefmt test helper (@brianmcgee)
- 48d4b4b: feat: remove globals from stats package (@brianmcgee)
- 202acb9: feat: remove relative path optimization in filesystem walker (@brianmcgee)
- bac4a0d: feat: replace kong with cobra/viper (@brianmcgee)
- 5d3de7c: feat: simplify .envrc (@brianmcgee)
- d195f79: feat: simplify devshell (@brianmcgee)
- 844f3fd: feat: simplify git walking (@brianmcgee)
- 93c8343: feat: simplify stats recording in filesystem reader (@brianmcgee)
- 8701a8f: feat: update flake inputs (@brianmcgee)
- 0ee561e: fix: correct handling of absolute and relative paths (@jfly)
- 4f1f3d6: fix: do not cache formatting errors (@brianmcgee)
- 6824497: fix: duplicate iota in walk.Type enum (@brianmcgee)
- 8aeee1d: fix: exit with error if any formatters fail (@brianmcgee)
- df4de90: fix: formatter_test (@brianmcgee)
- 2d3398c: fix: git module domain (@brianmcgee)
- f6d1b13: fix: golanci-lint workflow (@brianmcgee)
- 7740e3a: fix: gomod2nix.toml (@brianmcgee)
- 9ce6522: fix: normalize and enforce stdin paths as well (@jfly)
- 147dcdb: fix: path handling and checking git index (@brianmcgee)
- 5306a5e: fix: resolve commands relative to the root (@zimbatm)
- db7b305: fix: unmatched reporting global excludes (@brianmcgee)
- d490e98: fix: use PRJ_ROOT to find config (@brianmcgee)
v2.0.5
Bugfixes
- When walking the filesystem with
git
, we were skipping executable files. There is a test which should have detected this. In this case, the test also had a bug 🤦♂️ Thanks to @akshaymankar for the fix. The test has also been updated. This affects users using formatters such asshellcheck
orshfmt
to format their executable shell scripts.
--fail-on-change improvement
We now log the path that has changed at error
level, making it easier to understand why CI builds are failing.
Changelog
- c53a1f1: feat: log changed files at error level when --fail-on-change is enabled (@brianmcgee)
- a581352: fix: Do not exclude executables in git walker (@akshaymankar)
- 1734bcf: fix: remove assertFormatted, use assertStats instead (@brianmcgee)
Nixpkgs PR Tracker
v2.0.4
Bugfixes
- There was a naive optimisation for resolving relative paths within the walker implementations, which manifested in a few different issues. This has been refactored with a robust implementation.
- Searching for
.treefmt.toml
and relying on$PRJ_ROOT
have been re-introduced for parity withv1
. - We were not gracefully handling the case where a file was removed from the filesystem but not yet staged. We now log a warning and continue when this happens.
New CI flag
You can now run treefmt
with a --ci
flag which does the following:
- ensures
INFO
level logging at a minimum - enables
--no-cache
and--fail-on-change
- introduces a small startup delay, so we do not start processing until the second after the process starts, thereby ensuring the accuracy of our change detection based on second-level
mod
time. This was causing intermittent failures in CI due to how fast agit
checkout and subsequenttreefmt
invocation were occurring.
Changelog
- 52d8c48: Update nixpkgs.toml (@mattalxndr)
- 17c1785: Update treefmt.toml (@mattalxndr)
- d4aaba9: feat: ci mode (@brianmcgee)
- 0a8ffe0: feat: move filtering of directories and symlinks into walker implementations (@brianmcgee)
- ff8b1ed: feat: refactor relative path function for filesystem walker (@brianmcgee)
- 0953dd5: feat: refactor relative path function for git walker (@brianmcgee)
- bc1ae33: feat: search for .treefmt.toml (@zimbatm)
- 43c2071: fix(cli): restore PRJ_ROOT env var (@zimbatm)
- f9bc8b0: fix(git): gracefully handle a file in the index but not in the filesystem (@brianmcgee)
- a018c29: fix: relative path resolution in filesystem walker (@brianmcgee)
Nixpkgs PR Tracker
v2.0.3
Bugfixes
-
We were trying to open a cache file when using
-c --no-cache
, breaking some CI workflows. This is now handled more gracefully. -
When comparing
mod
times, we used the precision the underlying file system gave us. Some formatters, such asdos2unix
, manipulate themod
time, but not to the same precision. This was causing false positives when using--no-cache --fail-on-change
. We now truncate themod
time to second-level precision before comparing, as POSIX specifies thatmod
time should be EPOCH (second) precision. This brings us back in line withv1
behaviour.
Summary Improvements
We have improved the summary statistics presented at the end of each run, clarifying what has happened and removing unnecessary precision in the elapsed time.
❯ nix fmt
traversed 116 files
emitted 116 files for processing
formatted 67 files (0 changed) in 696ms
Changelog
- a642145: feat: display elapsed time to nearest millisecond (@brianmcgee)
- f266fc8: feat: if we can't open the cache, fallback to no cache (@brianmcgee)
- da7b015: feat: improve summary stats (@brianmcgee)
- 33a7bba: fix: --no-cache (@brianmcgee)
- 85ce0a2: fix: use second precision when comparing file mod times (@brianmcgee)
Nixpkgs PR Tracker
v2.0.2
Changelog
- 7d7815e: doc: fix global excludes config example (@brianmcgee)
- aea75cd: feat: remove CGO dependencies and disable (@brianmcgee)
- 986f020: feat: use numtide/blueprint instead of flake.parts (@brianmcgee)
- 2e05603: fix: configure toml tags for config fields (@brianmcgee)
- 601af09: fix: only try opening the cache if cache is enabled (@flokli)
v2.0.0-rc5
Changelog
- c07305e: cli: remove global state, init function usage (@katexochen)
- 56d8561: feat: improve unmatched logic (@brianmcgee)
- e29107d: fix: only cancel formatters on background errors (@zimbatm)
- c68261e: fix: stop hard-killing formatters (@zimbatm)
v2.0.1
We have rewritten treefmt
in Go but have tried to retain backward compatibility as much as possible.
For the most part, treefmt
2.0 should be a drop-in replacement for 1.0.
Users may find some behaviour differences in how treefmt
2.0 traverses the filesystem. Please review the new website treefmt.com for more info.
If you have any problems, please create an issue, and we will do our best to resolve it promptly.
For some background, you can read more here.
Features
- migrated cache storage from Toml to boltdb
- introduced the concept of
walkers
to make filesystem traversal extensible. It currently supportsauto
,git
, andfilesystem
. You no longer have to exclude the.git
directory; ' treefmtwill traverse files based on the git index if a
.git` directory is detected. - we now guarantee only one formatter will operate on a given path at any time.
- ordering for formatters can now be controlled with a new priority field.
- improved performance by up to 8x when cached based on a nixpkgs benchmark
- migrated docs from mkdocs to vitepress
- docs are now hosted under a custom domain, treefmt.com
Changelog
- c07305e: cli: remove global state, init function usage (@katexochen)
- 56d8561: feat: improve unmatched logic (@brianmcgee)
- e29107d: fix: only cancel formatters on background errors (@zimbatm)
- c68261e: fix: stop hard-killing formatters (@zimbatm)
- 088479e: Update cli/cli.go (@zimbatm)
- bd32d36: cli: search for the tree root by default (@zimbatm)
- bc89625: fix TreeRootFile type (@zimbatm)
- 089eb17: fix: --stdin flag (@brianmcgee)
- 0511e9a: fixes #309 (comment) (@zimbatm)
- 7f4697f: simplify logic (@zimbatm)
- 1b517c6: feat: add --on-unmatched (@brianmcgee)
- ce14ee8: feat: simplify pipeline model (@brianmcgee)
- ff3bfaa: feat: demote some cache related logging to debug level (@brianmcgee)
- 06e4145: feat: error out when a path matches multiple formatters (@brianmcgee)
- 385fbc3: feat: improve formatter cache debug logging (@brianmcgee)
- 3c264c6: feat: log out the formatter command being applied at debug level (@brianmcgee)
- c002eca: feat: log out when a path is not matched to any formatter (@brianmcgee)
- affbb99: feat: switch back to numtide/treefmt-nix (@brianmcgee)
- 24114f5: feat: update go modules (@brianmcgee)
- f7cc274: fix wording (@fricklerhandwerk)
- 4d07521: fix: -f short flag for specifying formatters (@brianmcgee)
- 3649e47: fix: support core.untrackedCache in git (@brianmcgee)
- 2b94480: fix: use resolved executable when applying a formatter (@brianmcgee)
- 187375c: README: update link to the Rust v1 (@zimbatm)
- 400d0c7: Revert "chore: temporarily remove settings.yml workflow" (@brianmcgee)
- 8de5446: Revert "ci: add go workflow" (@brianmcgee)
- 811f883: feat/bust-cache-validators-change (#14) (@brianmcgee)
- cb9564c: feat: add -s -w build flags to reduce binary size (@brianmcgee)
- 4ffe2ca: feat: add CGO dependencies to devshell (@brianmcgee)
- 2b49923: feat: add an example of 'before' (@brianmcgee)
- a79ae95: feat: add cpu profile flag (@brianmcgee)
- ad3e661: feat: add flake compat (@brianmcgee)
- aa75d3d: feat: add initial github workflow (@brianmcgee)
- 4dd4c55: feat: add nix direnv source to .envrc (@brianmcgee)
- ebfd17b: feat: add nix github workflow (@brianmcgee)
- 6ae0e4f: feat: add pipeline priority field (@brianmcgee)
- 0c5c34d: feat: add release workflow (@brianmcgee)
- 04330a3: feat: add stats output similar to treefmt.rs (@brianmcgee)
- 12452b0: feat: align example treefmt config with flake treefmt config (@brianmcgee)
- 4c45d2a: feat: allow missing formatters (#6) (@brianmcgee)
- 9b84155: feat: allow specifying formatters in cli (@brianmcgee)
- 298e5ac: feat: change module root to git.numtide.com (@brianmcgee)
- b6405d0: feat: clean up and documentation (@brianmcgee)
- 18bdb72: feat: compare with cache before reporting a file as changed (@brianmcgee)
- 757d5e7: feat: configure a pipeline for formatting nix code (@brianmcgee)
- b8d9e2a: feat: configure numtide binary cache (@brianmcgee)
- b109358: feat: create config package (#25) (@brianmcgee)
- 40b76b7: feat: ensure deterministic application of formatters (@brianmcgee)
- c71d690: feat: have each formatter filter paths again if part of a pipeline (@brianmcgee)
- 26c2ae1: feat: hex encode db name (@brianmcgee)
- 2ad87c2: feat: implement init (@brianmcgee)
- 92321c8: feat: improve specifying formatters test (@brianmcgee)
- 53ea16a: feat: improve stats assertion feedback (@brianmcgee)
- 8af5b3c: feat: introduce concept of pipelines for better concurrency (@brianmcgee)
- 7c137bf: feat: listen for shutdown correctly (@brianmcgee)
- 2e77e12: feat: optimize git walker (@brianmcgee)
- 2eaf999: feat: refactor some config init logic into config package (@brianmcgee)
- 9b00e00: feat: set nix package version to shortRev (@brianmcgee)
- ada9a72: feat: simplify some test code (@brianmcgee)
- 8b92dca: feat: streaming processing of paths from stdin and paths argument (@brianmcgee)
- da82b80: feat: support --no-cache (@brianmcgee)
- d53f98e: feat: support --version (@brianmcgee)
- 5711cae: feat: support .gitignore files (#19) (@brianmcgee)
- a3ca782: feat: support changing work directory (#15) (@brianmcgee)
- 84629f7: feat: support fail on change (#16) (@brianmcgee)
- 96b1560: feat: support global excludes (#13) (@zimbatm)
- 0fbae06: feat: support reading paths from stdin (@brianmcgee)
- 8e23c86: feat: update flake inputs (@brianmcgee)
- 1002f05: feat: update module go version to 1.22 (@brianmcgee)
- 28ec6f8: feat: upgrade modules (@brianmcgee)
- 0c93d98: feat: use a named type for Cli options (@brianmcgee)
- d8d666a: feat: use exec.LookPath to find formatter executable (@brianmcgee)
- 80e99b6: feat: use go-git index instead of
git ls-files
(#23) (@brianmcgee) - fcce518: feat: various perf improvements (@brianmcgee)
- 6c66daf: fix: devshell commands for docs (@brianmcgee)
- 15db7f4: fix: duplicate processing in ordered formatters (#24) (@brianmcgee)
- ed10f97: fix: fmt.Errorf formats (@brianmcgee)
- 12aa9a7: fix: glob patterns for includes and excludes (@brianmcgee)
- f322e1f: fix: include correct gotools package (@brianmcgee)
- 249f807: fix: install node dependencies in devshell commands (@brianmcgee)
- 25230e2: fix: license contributors (@brianmcgee)
- 4a78a1e: fix: nix build (@brianmcgee)
- 397d051: fix: nix filter for package (@brianmcgee)
- 3000c65: fix: nix-filter config for package (@brianmcgee)
- 5a5c1ea: fix: record cache entries for files that don't match formatters (@brianmcgee)
- cb8565d: fix: reduce log verbosity (@brianmcgee)
- 710efbd: fix: remember timestamps from logging (@brianmcgee)
- 97e94ba: fix: remove -dirty suffix ...
v2.0.0-rc4
v2.0.0-rc3
Changelog
- 1b517c6: feat: add --on-unmatched (@brianmcgee)
- ce14ee8: feat: simplify pipeline model (@brianmcgee)