Clone this repo:
  1. dedd929 Internal. by Kauê Soares da Silveira · 4 weeks ago master
  2. 1e18ef0 Make quote symbol preserved in multiline quoted strings. by txtpbfmt team · 3 months ago
  3. ef3ab17 Rollback of "Prevent blank lines between a comment and an item from moving with the item". by txtpbfmt team · 6 months ago
  4. 426a488 Sort list values if repeated field sorting is enabled. by txtpbfmt team · 6 months ago
  5. 5d63926 Prevent blank lines between a comment and an item from moving with the item. by txtpbfmt team · 6 months ago

Text Proto Formatter

txtpbfmt parses, edits and formats text proto files in a way that preserves comments.

This saves development (read/edit/review) time and enables automated edits.

How to format existing text proto files?

Install:

$ go install github.com/protocolbuffers/txtpbfmt/cmd/txtpbfmt@latest

Format files in-place:

$ ${GOPATH}/bin/txtpbfmt [FILES]

Write formatted input to stdout:

$ ${GOPATH}/bin/txtpbfmt < [FILE]

What does it do?

Main features:

main features

Configurable features:

Is there an API to edit text proto files while preserving comments?

Yes, see ast.go.

How to disable it?

You can disable formatting for a whole file by adding a comment with “# txtpbfmt: disable” to the top of the file (before the first non-empty non-comment line), eg:

# File overview ...

# txtpbfmt: disable

content: { ... }

Which file extension should I use for my text proto files?

The .textproto extension is the most used extension inside Google (the second most popular choice is .textpb).

Which tools support it? How to format on save?

Currently there is no open source integration with any editor.

See also