diff options
author | Rich Gowman <rgowman@google.com> | 2018-06-12 10:27:17 -0400 |
---|---|---|
committer | Rich Gowman <rgowman@google.com> | 2018-06-12 10:27:17 -0400 |
commit | cf2899a085f7ceca3fad2d1fb5336be25cecd7ff (patch) | |
tree | 38c835a29fcda279c8dd220781d2b5c726da307f /Firestore/Protos/build-protos.sh | |
parent | 1597765af8c897ab73d21d6d404f8eeede7890b1 (diff) | |
parent | 9307f4893008f7d6cf9473e906d4c896546c5c8c (diff) |
Merge remote-tracking branch 'origin/master' into rsgowman/protobuf_cpp
Also "fixed" BadFieldValueTagWithOtherValidTagsPresent test by changing
'false' to 'true'. Details: Depending on the version of nanopb, nanopb
would explicitly encode 'false', which shouldn't be done in proto3. When
it's explicitly encoded, the test worked properly. But when it was
(properly) dropped, the invalid tag is the only field that's actually
encoded, thus violating the assumptions of the test, leading to a test
failure. s/false/true fixes it, as now the boolean_value field is
(properly) encoded regardless of version.
Diffstat (limited to 'Firestore/Protos/build-protos.sh')
-rwxr-xr-x | Firestore/Protos/build-protos.sh | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/Firestore/Protos/build-protos.sh b/Firestore/Protos/build-protos.sh index d55ed55..2745a41 100755 --- a/Firestore/Protos/build-protos.sh +++ b/Firestore/Protos/build-protos.sh @@ -27,24 +27,36 @@ pod update --nanopb_out="--options-file=protos/%s.options:nanopb" \ `find protos -name *.proto -print | xargs` -# Remove "well-known" protos from objc. (We get these for free. We only need -# them for nanopb.) +# Remove "well-known" protos from objc and cpp. (We get these for free. We only +# need them for nanopb.) rm -rf objc/google/protobuf/ +rm -rf cpp/google/protobuf # If a proto uses a field named 'delete', nanopb happily uses that in the # message definition. Works fine for C; not so much for C++. Rename uses of this # to delete_ (which is how protoc does it for c++ files.) perl -i -pe 's/\bdelete\b/delete_/g' `find nanopb -type f` +# Rename nanopb's headers from foo.pb.h to foo.nanopb.h. This avoids collisions +# with libprotobuf. +for f in $(find nanopb -name \*.pb.h); do + mv "$f" "${f%.pb.h}.nanopb.h" +done + +# Adjust include paths to match +for f in $(find nanopb -name \*.h -or -name \*.c); do + perl -i -pe 's/(#include .*)\.pb\.h/\1.nanopb.h/' $f +done + # CocoaPods does not like paths in library imports, flatten them. -for i in `find objc -name "*.[mh]"` ; do +for i in $(find objc -name "*.[mh]"); do perl -i -pe 's#import ".*/#import "#' $i; done # Remove the unnecessary extensionRegistry functions. -for i in `find objc -name "*.[m]" ` ; do +for i in $(find objc -name "*.[m]"); do ./strip-registry.py $i done |