Clone this repo:

Branches

  1. 59ee516 [build] Propagate "testonly" to fix errors about it not being used by Mark Seaborn · 4 days ago main master
  2. 7aebe47 Merge "[build] Update visibility list" into main by Adam Barth · 6 days ago
  3. efec0ea [build] Update visibility list by Adam Barth · 6 days ago
  4. ff123a0 Add instructions for updating BUILD.gn. by Anivia Li · 5 months ago
  5. 7d2a723 Ignore generator_visibility parameter by Clayton Wilkinson · 7 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.