goprotowrap
protoc got smarter: you should no longer need this
A package-at-a-time wrapper for protoc, for generating Go protobuf
code.
protowrap is a small tool we found helpful when working with
protocol buffers in
Go at Square. We're publishing it in the hope that others find it
useful too. Contributions are welcome.
Install
go get -u github.com/square/goprotowrap/cmd/protowrapPhilosophy
Unlike other language plugins, the Go
protobuf plugin expects to be
called separately for each package, and given all files in that (fixed).
package
protowrap is called instead of protoc, and ensures that .proto
files are processed one Go package at a time.
It parses out the flags it understands, passing the rest through to
protoc unchanged.
Operation
- search for all
.protofiles under the same import paths as the
.protofile arguments - call
protocto generate FileDescriptorProtos - inspect the FileDescriptorProtos to deduce package information
- group
.protofiles into packages - call
protoconce for each package
TODOs
- Replace square-specific handling of
go_packagewith
recently updated upstream logic. - In the initial call to
protocfor generating
FileDescriptorProtos, pass.protofiles toprotocin batches
instead of all at once. - Better tests, especially of the code paths not exercised by our
build process.
License
Copyright 2016 Square, Inc.
Licensed under the Apache License, Version 2.0 (the "License"); you
may not use this file except in compliance with the License. You may
obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
implied. See the License for the specific language governing
permissions and limitations under the License.