build-zip.sh 3.7 KB

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