-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add rule for arg / stage name comment descriptions
Signed-off-by: Talon Bowler <talon.bowler@docker.com>
- Loading branch information
Showing
6 changed files
with
259 additions
and
12 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
66 changes: 66 additions & 0 deletions
66
frontend/dockerfile/docs/rules/invalid-definition-description.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,66 @@ | ||
--- | ||
title: InvalidDefinitionDescription | ||
description: Comment for build stage or argument should follow the format: `# <arg/stage name> <description>`. If this is not intended to be a description comment, add an empty line or comment between the instruction and the comment. | ||
aliases: | ||
- /go/dockerfile/rule/invalid-definition-description/ | ||
--- | ||
|
||
## Output | ||
|
||
```text | ||
Comment for build stage or argument should follow the format: `# <arg/stage name> <description>`. If this is not intended to be a description comment, add an empty line or comment between the instruction and the comment. | ||
``` | ||
|
||
## Description | ||
|
||
The [`--call=outline`](https://docs.docker.com/reference/cli/docker/buildx/build/#call-outline) | ||
and [`--call=targets`](https://docs.docker.com/reference/cli/docker/buildx/build/#call-outline) | ||
flags for the `docker build` command print descriptions for build targets and arguments. | ||
The descriptions are generated from [Dockerfile comments](https://docs.docker.com/reference/cli/docker/buildx/build/#descriptions) | ||
that immediately precede the `FROM` or `ARG` instruction | ||
and that begin with the name of the build stage or argument. | ||
For example: | ||
|
||
```dockerfile | ||
# build-cli builds the CLI binary | ||
FROM alpine AS build-cli | ||
# VERSION controls the version of the program | ||
ARG VERSION=1 | ||
``` | ||
|
||
In cases where preceding comments are not meant to be descriptions, | ||
add an empty line or comment between the instruction and the preceding comment. | ||
|
||
## Examples | ||
|
||
❌ Bad: A non-descriptive comment on the line preceding the `FROM` command. | ||
|
||
```dockerfile | ||
# a non-descriptive comment | ||
FROM scratch AS base | ||
|
||
# another non-descriptive comment | ||
ARG VERSION=1 | ||
``` | ||
|
||
✅ Good: An empty line separating non-descriptive comments. | ||
|
||
```dockerfile | ||
# a non-descriptive comment | ||
|
||
FROM scratch AS base | ||
|
||
# another non-descriptive comment | ||
|
||
ARG VERSION=1 | ||
``` | ||
|
||
✅ Good: Comments describing `ARG` keys and stages immediately proceeding the command. | ||
|
||
```dockerfile | ||
# base This is the base stage. | ||
FROM scratch AS base | ||
# VERSION This is the version number. | ||
ARG VERSION=1 | ||
``` | ||
|
Oops, something went wrong.