Clone this repo:

Branches

  1. ff123a0 Add instructions for updating BUILD.gn. by Anivia Li · 3 weeks ago main master
  2. 7d2a723 Ignore generator_visibility parameter by Clayton Wilkinson · 2 months ago
  3. 2700089 Merge "Add profiler to protobuf allowlist in the BUILD.input.gn" into main by Anivia Li · 3 months ago
  4. 310fcd4 Add profiler to protobuf allowlist in the BUILD.input.gn by Anivia Li · 3 months ago
  5. 1024ff0 Merge "Uprev protobuf build rules to match v29.0" into main by Anivia Li · 3 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.