build-zip.sh 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. #!/bin/bash
  2. if [ $# -ne 2 ]; then
  3. cat <<EOF
  4. Usage: $0 <TARGET> <VERSION_NUMBER>
  5. TARGET: protoc | protoc-gen-javalite
  6. Example:
  7. $ $0 protoc 3.0.0
  8. $ $0 protoc-gen-javalite 3.0.0
  9. This script will download pre-built protoc or protoc plugin binaries from maven
  10. repository and create .zip packages suitable to be included in the github
  11. release page. If the target is protoc, well-known type .proto files will also be
  12. included. Each invocation will create 6 zip packages:
  13. dist/<TARGET>-<VERSION_NUMBER>-win32.zip
  14. dist/<TARGET>-<VERSION_NUMBER>-osx-x86_32.zip
  15. dist/<TARGET>-<VERSION_NUMBER>-osx-x86_64.zip
  16. dist/<TARGET>-<VERSION_NUMBER>-linux-x86_32.zip
  17. dist/<TARGET>-<VERSION_NUMBER>-linux-x86_64.zip
  18. dist/<TARGET>-<VERSION_NUMBER>-linux-aarch_64.zip
  19. EOF
  20. exit 1
  21. fi
  22. TARGET=$1
  23. VERSION_NUMBER=$2
  24. # <zip file name> <binary file name> pairs.
  25. declare -a FILE_NAMES=( \
  26. win32.zip windows-x86_32.exe \
  27. osx-x86_32.zip osx-x86_32.exe \
  28. osx-x86_64.zip osx-x86_64.exe \
  29. linux-x86_32.zip linux-x86_32.exe \
  30. linux-x86_64.zip linux-x86_64.exe \
  31. linux-aarch_64.zip linux-aarch_64.exe \
  32. )
  33. # List of all well-known types to be included.
  34. declare -a WELL_KNOWN_TYPES=( \
  35. google/protobuf/descriptor.proto \
  36. google/protobuf/any.proto \
  37. google/protobuf/api.proto \
  38. google/protobuf/duration.proto \
  39. google/protobuf/empty.proto \
  40. google/protobuf/field_mask.proto \
  41. google/protobuf/source_context.proto \
  42. google/protobuf/struct.proto \
  43. google/protobuf/timestamp.proto \
  44. google/protobuf/type.proto \
  45. google/protobuf/wrappers.proto \
  46. google/protobuf/compiler/plugin.proto \
  47. )
  48. set -e
  49. # A temporary working directory to put all files.
  50. DIR=$(mktemp -d)
  51. # Copy over well-known types.
  52. mkdir -p ${DIR}/include/google/protobuf/compiler
  53. for PROTO in ${WELL_KNOWN_TYPES[@]}; do
  54. cp -f ../src/${PROTO} ${DIR}/include/${PROTO}
  55. done
  56. # Create a readme file.
  57. cat <<EOF > ${DIR}/readme.txt
  58. Protocol Buffers - Google's data interchange format
  59. Copyright 2008 Google Inc.
  60. https://developers.google.com/protocol-buffers/
  61. This package contains a precompiled binary version of the protocol buffer
  62. compiler (protoc). This binary is intended for users who want to use Protocol
  63. Buffers in languages other than C++ but do not want to compile protoc
  64. themselves. To install, simply place this binary somewhere in your PATH.
  65. If you intend to use the included well known types then don't forget to
  66. copy the contents of the 'include' directory somewhere as well, for example
  67. into '/usr/local/include/'.
  68. Please refer to our official github site for more installation instructions:
  69. https://github.com/google/protobuf
  70. EOF
  71. mkdir -p dist
  72. mkdir -p ${DIR}/bin
  73. # Create a zip file for each binary.
  74. for((i=0;i<${#FILE_NAMES[@]};i+=2));do
  75. ZIP_NAME=${FILE_NAMES[$i]}
  76. if [ ${ZIP_NAME:0:3} = "win" ]; then
  77. BINARY="$TARGET.exe"
  78. else
  79. BINARY="$TARGET"
  80. fi
  81. BINARY_NAME=${FILE_NAMES[$(($i+1))]}
  82. BINARY_URL=http://repo1.maven.org/maven2/com/google/protobuf/$TARGET/${VERSION_NUMBER}/$TARGET-${VERSION_NUMBER}-${BINARY_NAME}
  83. if ! wget ${BINARY_URL} -O ${DIR}/bin/$BINARY &> /dev/null; then
  84. echo "[ERROR] Failed to download ${BINARY_URL}" >&2
  85. echo "[ERROR] Skipped $TARGET-${VERSION_NAME}-${ZIP_NAME}" >&2
  86. continue
  87. fi
  88. TARGET_ZIP_FILE=`pwd`/dist/$TARGET-${VERSION_NUMBER}-${ZIP_NAME}
  89. pushd $DIR &> /dev/null
  90. chmod +x bin/$BINARY
  91. if [ "$TARGET" = "protoc" ]; then
  92. zip -r ${TARGET_ZIP_FILE} include bin readme.txt &> /dev/null
  93. else
  94. zip -r ${TARGET_ZIP_FILE} bin &> /dev/null
  95. fi
  96. rm bin/$BINARY
  97. popd &> /dev/null
  98. echo "[INFO] Successfully created ${TARGET_ZIP_FILE}"
  99. done