reteps/dockerfmt: Dockerfile format and parser. a modern dockfmt.

Date:

Share:

Dockerfile format and parser, and a modern version of dockfmt. Built on top of the internal buildkit parser.

Binaries are available from the releases page.

A updated version of the dockfmt. Uses the dockerfile parser from moby/buildkit and the shell formatter from mvdan/sh.

Usage:
  dockerfmt [Dockerfile] [flags]
  dockerfmt [command]

Available Commands:
  completion  Generate the autocompletion script for the specified shell
  help        Help about any command
  version     Print the version number of dockerfmt

Flags:
  -c, --check         Check if the file(s) are formatted
  -h, --help          help for dockerfmt
  -i, --indent uint   Number of spaces to use for indentation (default 4)
  -n, --newline       End the file with a trailing newline
  -w, --write         Write the formatted output back to the file(s)

Use "dockerfmt [command] --help" for more information about a command.
  • The RUN parser currently doesn’t support grouping or semicolons in commands
  • No line wrapping is performed for long JSON commands
  • The # escape=X directive is not supported

Contributions are welcome!

RUN <"hello"
echo "world"
EOF
  • Support for basic inline comments in run steps:
RUN echo "hello" \
    # this is a comment
    && echo "world"
RUN echo "hello" \
    # this is a comment
    # that spans multiple lines
    && echo "world"

This is surprisingly non-trivial as we want to attach the comments to their position in the formatted output, but they are stripped by the parser beforehand.

The JS bindings are available in the js directory. More information on how to use them can be found in the README file.

Source link

Subscribe to our magazine

━ more like this

Fangor Mosaics in Warsaw, Poland

The Warszawa Śródmieście Railway Station is used by thousands of commuters every day, yet many of them don’t even notice the beautiful ceramic...

Old Navy x Anna Sui Collab Blends Two 90s Fashion Icons

Calling all fashion lovers because the nineties... and seventies... and sixties called, and they want to be back inside your closets. Luckily, New York-based...

Analog(ue) #197: I Enjoy It But I’m Very Bad At It

#197: I Enjoy It But I’m Very Bad At It January 9th, 2022 · 87 minutes Myke thinks Casey is bad at Wordle, Casey thinks he's bad at...