Clone this repo:
  1. 16587c7 Refactor processChar to reduce complexity by Kauê Soares da Silveira · 3 weeks ago master
  2. 0b0c270 Refactor parseList to reduce complexity by Kauê Soares da Silveira · 4 weeks ago
  3. 3c4024c Refactor the parse function in third_party/txtpbfmt/impl.go to reduce its complexity. by Kauê Soares da Silveira · 4 weeks ago
  4. ff5ff96 Merge pull request #179 from mhsong21:sort-by-descriptor-field by txtpbfmt team · 5 weeks ago
  5. 41497d5 fix impl_test.go by martin · 6 weeks 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