An open API service indexing awesome lists of open source software.

https://github.com/rodaine/protoc-gen-visibility

Cascading visibility rules for protobufs
https://github.com/rodaine/protoc-gen-visibility

buf protoc protoc-plugin protocol-buffers

Last synced: about 1 year ago
JSON representation

Cascading visibility rules for protobufs

Awesome Lists containing this project

README

          

# protoc-gen-visibility

_Set cascading visibility rules for Protocol Buffer files, messages, and enums._

## Example

```protobuf
// ./protos/widgets/v1/widget.proto
syntax = "proto3";
package widgets.v1;

import "visibility/v1/visibility.proto";

option (visibility.v1.file_rules) = {
mode: MODE_PACKAGE, // entities in this file are package-private...
packages: [ // ...and also visible to these packages:
"gizmos.v1",
"gadgets.*"
]
};

// ...
```

`protoc-gen-visibility` is executed like any other protoc plugin, but does not generate output files. The plugin errors if there is a violation of the visibility specificiation:

```shell
$ protoc --visibility_out=. ./protos/gadgets/v1/gadget.proto
# exits 0

$ protoc --visibility_out=. ./protos/gizmos/v2/gizmo.proto
--visibility_out: visibility constraints have been violated:
- protos/gizmos/v2/gizmo.proto: gizmos.v2.Gizmo includes widgets.v1.Widget (MODE_PACKAGE)
# exits 1
```