Clone this repo:

Branches

  1. bad49a4 Add update-package to protoc visibility by Sen Jiang · 3 weeks ago main master
  2. 59ee516 [build] Propagate "testonly" to fix errors about it not being used by Mark Seaborn · 5 weeks ago
  3. 7aebe47 Merge "[build] Update visibility list" into main by Adam Barth · 5 weeks ago
  4. efec0ea [build] Update visibility list by Adam Barth · 5 weeks ago
  5. ff123a0 Add instructions for updating BUILD.gn. by Anivia Li · 6 months ago

Protocol Buffers GN Build Support

This repository contains GN build system support for Protocol Buffers. It's in its own repository because it needs to be shared by Fuchsia and Cobalt.

This repo should be checked out such that:

  • It is in //build/secondary/third_party/protobuf.
  • Protobuf is in //third_party/protobuf.
  • //.gn contains secondary_source = "//build/secondary/"

See the GN documentation on secondary_source.

Updating Build Files

WARNING: DO NOT MODIFY THE BUILD.gn FILE DIRECTLY!

The BUILD.gn file in this directory is generated automatically. Any manual changes will be overwritten.

To make changes to the build configuration:

  1. Edit the BUILD.input.gn file to suit your needs, for example managing visibility, suppressing warnings, etc.
  2. Checkout //third_party/protobuf to the target version.
  3. Run the gen.py script located in this directory to regenerate the BUILD.gn file.
  4. Commit both the updated BUILD.input.gn and the newly generated BUILD.gn file.

Failing to modify BUILD.input.gn will result in your changes being lost the next time the build file is regenerated.