Index: third_party/protobuf/protoc-artifacts/build-zip.sh |
diff --git a/third_party/protobuf/protoc-artifacts/build-zip.sh b/third_party/protobuf/protoc-artifacts/build-zip.sh |
new file mode 100755 |
index 0000000000000000000000000000000000000000..3c5e887b290885ea69daf2a5d9580d13c026d398 |
--- /dev/null |
+++ b/third_party/protobuf/protoc-artifacts/build-zip.sh |
@@ -0,0 +1,108 @@ |
+#!/bin/bash |
+ |
+if [ $# -ne 2 ]; then |
+ cat <<EOF |
+Usage: $0 <TARGET> <VERSION_NUMBER> |
+ |
+TARGET: protoc | protoc-gen-javalite |
+ |
+Example: |
+ $ $0 protoc 3.0.0 |
+ $ $0 protoc-gen-javalite 3.0.0 |
+ |
+This script will download pre-built protoc or protoc plugin binaries from maven |
+repository and create .zip packages suitable to be included in the github |
+release page. If the target is protoc, well-known type .proto files will also be |
+included. Each invocation will create 5 zip packages: |
+ dist/<TARGET>-<VERSION_NUMBER>-win32.zip |
+ dist/<TARGET>-<VERSION_NUMBER>-osx-x86_32.zip |
+ dist/<TARGET>-<VERSION_NUMBER>-osx-x86_64.zip |
+ dist/<TARGET>-<VERSION_NUMBER>-linux-x86_32.zip |
+ dist/<TARGET>-<VERSION_NUMBER>-linux-x86_64.zip |
+EOF |
+ exit 1 |
+fi |
+ |
+TARGET=$1 |
+VERSION_NUMBER=$2 |
+ |
+# <zip file name> <binary file name> pairs. |
+declare -a FILE_NAMES=( \ |
+ win32.zip windows-x86_32.exe \ |
+ osx-x86_32.zip osx-x86_32.exe \ |
+ osx-x86_64.zip osx-x86_64.exe \ |
+ linux-x86_32.zip linux-x86_32.exe \ |
+ linux-x86_64.zip linux-x86_64.exe \ |
+) |
+ |
+# List of all well-known types to be included. |
+declare -a WELL_KNOWN_TYPES=( \ |
+ google/protobuf/descriptor.proto \ |
+ google/protobuf/any.proto \ |
+ google/protobuf/api.proto \ |
+ google/protobuf/duration.proto \ |
+ google/protobuf/empty.proto \ |
+ google/protobuf/field_mask.proto \ |
+ google/protobuf/source_context.proto \ |
+ google/protobuf/struct.proto \ |
+ google/protobuf/timestamp.proto \ |
+ google/protobuf/type.proto \ |
+ google/protobuf/wrappers.proto \ |
+ google/protobuf/compiler/plugin.proto \ |
+) |
+ |
+set -e |
+ |
+# A temporary working directory to put all files. |
+DIR=$(mktemp -d) |
+ |
+# Copy over well-known types. |
+mkdir -p ${DIR}/include/google/protobuf/compiler |
+for PROTO in ${WELL_KNOWN_TYPES[@]}; do |
+ cp -f ../src/${PROTO} ${DIR}/include/${PROTO} |
+done |
+ |
+# Create a readme file. |
+cat <<EOF > ${DIR}/readme.txt |
+Protocol Buffers - Google's data interchange format |
+Copyright 2008 Google Inc. |
+https://developers.google.com/protocol-buffers/ |
+ |
+This package contains a precompiled binary version of the protocol buffer |
+compiler (protoc). This binary is intended for users who want to use Protocol |
+Buffers in languages other than C++ but do not want to compile protoc |
+themselves. To install, simply place this binary somewhere in your PATH. |
+ |
+Please refer to our official github site for more installation instructions: |
+ https://github.com/google/protobuf |
+EOF |
+ |
+mkdir -p dist |
+mkdir -p ${DIR}/bin |
+# Create a zip file for each binary. |
+for((i=0;i<${#FILE_NAMES[@]};i+=2));do |
+ ZIP_NAME=${FILE_NAMES[$i]} |
+ if [ ${ZIP_NAME:0:3} = "win" ]; then |
+ BINARY="$TARGET.exe" |
+ else |
+ BINARY="$TARGET" |
+ fi |
+ BINARY_NAME=${FILE_NAMES[$(($i+1))]} |
+ BINARY_URL=http://repo1.maven.org/maven2/com/google/protobuf/$TARGET/${VERSION_NUMBER}/$TARGET-${VERSION_NUMBER}-${BINARY_NAME} |
+ if ! wget ${BINARY_URL} -O ${DIR}/bin/$BINARY &> /dev/null; then |
+ echo "[ERROR] Failed to download ${BINARY_URL}" >&2 |
+ echo "[ERROR] Skipped $TARGET-${VERSION_NAME}-${ZIP_NAME}" >&2 |
+ continue |
+ fi |
+ TARGET_ZIP_FILE=`pwd`/dist/$TARGET-${VERSION_NUMBER}-${ZIP_NAME} |
+ pushd $DIR &> /dev/null |
+ chmod +x bin/$BINARY |
+ if [ "$TARGET" = "protoc" ]; then |
+ zip -r ${TARGET_ZIP_FILE} include bin readme.txt &> /dev/null |
+ else |
+ zip -r ${TARGET_ZIP_FILE} bin &> /dev/null |
+ fi |
+ rm bin/$BINARY |
+ popd &> /dev/null |
+ echo "[INFO] Successfully created ${TARGET_ZIP_FILE}" |
+done |