From 7b2d7d0fb4c3065001612bff093def0bd6fb2b6c Mon Sep 17 00:00:00 2001
From: Rose M Koron <32436232+rkoron007@users.noreply.github.com>
Date: Fri, 13 Dec 2024 10:53:26 -0800
Subject: [PATCH] Document the `tfstacks fmt` command (#36202)
---
website/docs/cli/commands/fmt.mdx | 31 ++++++++--------
.../stacks/reference/tfstacks-cli.mdx | 36 ++++++++++++++++---
2 files changed, 46 insertions(+), 21 deletions(-)
diff --git a/website/docs/cli/commands/fmt.mdx b/website/docs/cli/commands/fmt.mdx
index 5c5ad2f30403..33c72b60d564 100644
--- a/website/docs/cli/commands/fmt.mdx
+++ b/website/docs/cli/commands/fmt.mdx
@@ -47,20 +47,17 @@ and the generated files.
Usage: `terraform fmt [options] [target...]`
-By default, `fmt` scans the current directory for configuration files. If you
-provide a directory for the `target` argument, then `fmt` will scan that
-directory instead. If you provide a file, then `fmt` will process just that
-file. If you provide a single dash (`-`), then `fmt` will read from standard
-input (STDIN).
-
-
-The command-line flags are all optional. If no flag is given, `fmt` rewrites
-the Terraform configuration files to a canonical format and style.
-
-The following flags are available:
-
-* `-list=false` - Don't list the files containing formatting inconsistencies.
-* `-write=false` - Don't overwrite the input files. (This is implied by `-check` or when the input is STDIN.)
-* `-diff` - Display diffs of formatting changes.
-* `-check` - Check if the input is formatted. Exit status will be 0 if all input is properly formatted. If not, exit status will be non-zero and the command will output a list of filenames whose files are not properly formatted.
-* `-recursive` - Also process files in subdirectories. By default, only the given directory (or current directory) is processed.
+By default, the `terraform fmt` command scans your current directory for configuration files. You can also provide a `target` argument to tell `terraform fmt` to scan:
+* A directory
+* A specific file
+* Standard input by supplying a single dash (`-`).
+
+The `terraform fmt` command accepts the following arguments.
+
+| Flag | Description | Required |
+| :---- | :---- | :---- |
+| `-list=false` | Prevents the command from listing the files containing formatting inconsistencies. | Optional |
+| `-diff` | Displays the diffs of formatting changes. | Optional |
+| `-write=false` | Prevents the command from overwriting files. This behavior is implied by the `-check` flag or if the input is from `STDIN`. | Optional |
+| `-check` | Checks if the input is formatted. The exit status is `0` if the command's input is properly formatted. Otherwise, the exit status is non-zero, and the command outputs a list of improperly formatted file names. | Optional |
+| `-recursive` | Processes files in subdirectories in addition to the current directory. By default, the command only processes the specified, or current, directory. | Optional |
diff --git a/website/docs/language/stacks/reference/tfstacks-cli.mdx b/website/docs/language/stacks/reference/tfstacks-cli.mdx
index 48a4892f6c04..5f0ed006e33e 100644
--- a/website/docs/language/stacks/reference/tfstacks-cli.mdx
+++ b/website/docs/language/stacks/reference/tfstacks-cli.mdx
@@ -72,10 +72,11 @@ $ sudo yum -y install terraform-stacks-cli
The `terraform-stacks-cli` supports the following four commands:
-* `tfstacks init`
-* `tfstacks validate`
-* `tfstacks providers lock [-platform=os_arch]`
-* `tfstacks plan -organization=org_name -stack=stack_id -deployment=deployment_name [-hostname=hostname]`
+* [`tfstacks init`](#tfstacks-init-command)
+* [`tfstacks validate`](#tfstacks-validate-command)
+* [`tfstacks providers lock [-platform=os_arch]`](#tfstacks-providers-lock-command)
+* [`tfstacks plan -organization=org_name -stack=stack_id -deployment=deployment_name [-hostname=hostname]`](#tfstacks-plan-command)
+* [`tfstacks fmt`](#tfstacks-fmt-command)
Each Stack command supports [global options](#global-options).
@@ -128,6 +129,33 @@ The `tfstacks plan` accepts the following arguments.
| `-deployment=` | Set the `deployment` flag to the deployment name you want to perform this plan in. The deployment name must match one of the deployment names you specified in the `tfdeploy.hcl` file.
Alternatively, you can set an environment variable named `TFSTACKS_DEPLOYMENT` with the same value. | Required |
| `-hostname=` | You can set the `hostname` flag to the hostname of the HCP Terraform instance you want to perform this plan in. The default value is `app.terraform.io`.
Alternatively, you can set an environment variable named `TFSTACKS_HOSTNAME` with the same value. | Optional |
+### `tfstacks fmt` command
+
+-> The `tfstacks fmt` command requires v0.6.0 of the `terraform-stacks-cli` or higher. Refer to [installation](#installation) for instructions.
+
+The `tfstacks fmt` command scans your current directory for Stack configuration files, `.tfstack.hcl` and `.tfdeploy.hcl`, and formats those files to match Terraform's canonical format and style.
+
+```shell-session
+$ tfstacks fmt [options] [target]
+```
+
+By default, the `tfstacks fmt` command scans your current directory for configuration files. You can also provide a `target` argument to tell `tfstacks fmt` to scan:
+* A directory
+* A specific file
+* Standard input by supplying a single dash (`-`).
+
+The `tfstacks fmt` command accepts the following arguments.
+
+| Flag | Description | Required |
+| :---- | :---- | :---- |
+| `-list=false` | Prevents the command from listing the files containing formatting inconsistencies. | Optional |
+| `-diff` | Displays the diffs of formatting changes. | Optional |
+| `-write=false` | Prevents the command from overwriting files. This behavior is implied by the `-check` flag or if the input is from `STDIN`. | Optional |
+| `-check` | Checks if the input is formatted. The exit status is `0` if the command's input is properly formatted. Otherwise, the exit status is non-zero, and the command outputs a list of improperly formatted file names. | Optional |
+| `-recursive` | Processes files in subdirectories in addition to the current directory. By default, only the specified directory is processed. | Optional |
+
+The `tfstacks fmt` command uses the same formatting rules as the Terraform CLI's `terraform fmt` command. Refer to [`terraform fmt`](/terraform/cli/commands/fmt) for more information on formatting rules.
+
## Global options
You can apply the following global options to any `tfstacks` command: