tfsort
is a command-line utility designed for meticulous engineers who prefer to keep their Terraform variable
, output
, locals
and terraform
blocks sorted alphabetically. It also corrects spacing issues between these blocks and removes leading or trailing newlines in the processed files. tfsort
can read from files or stdin, write to files or stdout, and process directories recursively.
- Demo
- Key Features
- Supported File Types
- Installation
- Usage
- Examples
- Contributing
- Code of Conduct
- Author
- License
- Alphabetical Sorting: Sorts
variable
,output
,locals
andterraform
blocks within your HCL files. - Flexible Input/Output:
- Read from a specific file, directory or standard input (stdin).
- Overwrite the input file, write to a new file, or print to standard output (stdout).
- Recursive Processing: Sort files in an entire directory and its subdirectories.
- Skips common version control (
.git
) and Terraform utility directories (.terraform
,.terragrunt-cache
).
- Skips common version control (
- Dry Run Mode: Preview changes without modifying any files.
- Code Formatting:
- Corrects spacing between sorted blocks.
- Removes unnecessary leading or trailing newlines from the file.
tfsort
processes files with the following extensions:
.tf
.hcl
.tofu
To install tfsort
using Homebrew:
-
Add the tap:
brew tap alexnabokikh/tfsort
-
Install
tfsort
:brew install tfsort
nix-env -iA nixpkgs.tfsort
To install tfsort
using Chocolatey:
choco install tfsort
If you have Go installed and configured, you can install tfsort
directly using go install
:
go install github.com/AlexNabokikh/tfsort@latest
This command will download the source code, compile it, and install the tfsort
binary into your $GOPATH/bin
or $GOBIN
directory (make sure this directory is in your system's PATH
).
Download the latest binary release for your operating system from the Releases Page.
Alternatively, build tfsort
from source:
-
Clone the repository:
git clone https://github.com/AlexNabokikh/tfsort.git cd tfsort
-
Build the binary:
go build .
This will create a
tfsort
executable in the current directory.
tfsort [flags] [files...]
files
- Path to Terraform/HCL files (e.g.,
variables.tf
) - Path to directories to process recursively
- The character
-
instructstfsort
to read input from _standard input (stdin). For examplecat file.tf | tfsort -
will read from stdin.
- Path to Terraform/HCL files (e.g.,
- If no arguments are provided and stdin is not a pipe,
tfsort
will show the help message.
-o, --out <path>
:- Specifies the path to the output file.
- If the input is a file and
-o
is not provided, the input file is overwritten. - If the input is stdin and
-o
is not provided, the output is sent to stdout. - This flag cannot be used with
-r, --recursive
.
-d, --dry-run
:- Previews the changes by printing the sorted content to stdout.
- No files will be modified when this flag is used.
-h, --help
:- Displays a comprehensive help message, listing available commands, arguments, and flags with their descriptions.
-v, --version
:- Displays the installed version of the
tfsort
application, typically including the version number, commit hash, and build date if available.
- Displays the installed version of the
-
Sort a single file in-place: (Sorts
variable
,output
,locals
andterraform
blocks inmy_variables.tf
and overwrites the file)tfsort my_variables.tf
-
Sort a single file and write to a new file:
tfsort -o sorted_variables.tf my_variables.tf
-
Preview changes for a single file (dry run): (Prints the sorted content to the console without modifying
my_variables.tf
)tfsort -d my_variables.tf
-
Sort content from stdin and print to stdout:
cat my_config.tf | tfsort -
-
Sort content from stdin and write to a file:
cat my_config.tf | tfsort -o sorted_from_stdin.tf -
-
Recursively sort files in a directory (in-place): (Sorts all
.tf
,.hcl
,.tofu
files inmy_terraform_project/
and its subdirectories, modifying them in-place. Skips.git
,.terraform
,.terragrunt-cache
.)tfsort ./my_terraform_project/
-
Recursively sort files in a directory (dry run): (Prints what would be changed for each file to the console without modifying them.)
tfsort -d ./my_terraform_project/
Contributions are welcome! Please read the CONTRIBUTING.md file for guidelines on how to contribute to this project, including code contributions, bug reports, and feature suggestions.
This project adheres to the Contributor Covenant Code of Conduct. By participating, you are expected to uphold this code. Please read the CODE_OF_CONDUCT.md file for details.
This project was created by Alexander Nabokikh.
This software is available under the following licenses: