Clone this repo:
  1. a5fe556 Add a config called reverse_sort to reverse the sort order of sort_* configs by txtpbfmt team · 8 weeks ago master
  2. bcaa210 Generalize sort_repeated_fields_by_subfield to any path to the subfields. by txtpbfmt team · 9 weeks ago
  3. 1ee4910 chomp carriage returns by txtpbfmt team · 3 months ago
  4. 30b622f change to go ver to 1.19 by txtpbfmt team · 3 months ago
  5. feedd82 Merge pull request #127 from protocolbuffers:dependabot/go_modules/github.com/golang/glog-1.2.4 by txtpbfmt team · 4 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