diff options
author | Googler <noreply@google.com> | 2015-07-30 22:52:24 +0000 |
---|---|---|
committer | Damien Martin-Guillerez <dmarting@google.com> | 2015-08-04 09:05:49 +0000 |
commit | da3cb806351e929becef19652c65d39efa61b9d9 (patch) | |
tree | 9a958e75da52fc9d40c1fed1db5ea44e89f934d7 /src/tools/xcode | |
parent | 73d4fc94dff31477e7882286784001956b170863 (diff) |
RELNOTES: actoolzip, momczip and swiftstdlibtoolzip have all been made into bash scripts and have been renamed to actoolwrapper, momcwrapper and swiftstdlibtoolwrapper respectively. The old versions will be deleted in a later change.
--
MOS_MIGRATED_REVID=99521906
Diffstat (limited to 'src/tools/xcode')
-rw-r--r-- | src/tools/xcode/actoolwrapper/BUILD | 12 | ||||
-rw-r--r-- | src/tools/xcode/actoolwrapper/README | 6 | ||||
-rwxr-xr-x | src/tools/xcode/actoolwrapper/actoolwrapper.sh | 71 | ||||
-rwxr-xr-x | src/tools/xcode/ibtoolwrapper/ibtoolwrapper.sh | 14 | ||||
-rw-r--r-- | src/tools/xcode/momcwrapper/BUILD | 12 | ||||
-rw-r--r-- | src/tools/xcode/momcwrapper/README | 6 | ||||
-rwxr-xr-x | src/tools/xcode/momcwrapper/momcwrapper.sh | 38 | ||||
-rw-r--r-- | src/tools/xcode/swiftstdlibtoolwrapper/BUILD | 12 | ||||
-rw-r--r-- | src/tools/xcode/swiftstdlibtoolwrapper/README | 6 | ||||
-rwxr-xr-x | src/tools/xcode/swiftstdlibtoolwrapper/swiftstdlibtoolwrapper.sh | 39 |
10 files changed, 211 insertions, 5 deletions
diff --git a/src/tools/xcode/actoolwrapper/BUILD b/src/tools/xcode/actoolwrapper/BUILD new file mode 100644 index 0000000000..79bfdd6eda --- /dev/null +++ b/src/tools/xcode/actoolwrapper/BUILD @@ -0,0 +1,12 @@ +package(default_visibility = ["//src/test:__subpackages__"]) + +filegroup( + name = "srcs", + srcs = glob(["**"]), +) + +sh_binary( + name = "actoolwrapper", + srcs = ["actoolwrapper.sh"], + data = ["//src/tools/xcode/realpath:realpath_genrule"], +) diff --git a/src/tools/xcode/actoolwrapper/README b/src/tools/xcode/actoolwrapper/README new file mode 100644 index 0000000000..d274e63ec1 --- /dev/null +++ b/src/tools/xcode/actoolwrapper/README @@ -0,0 +1,6 @@ +actoolwrapper runs actool, which compiles asset catalog files. +actoolwrapper then zips up the output, because actool returns an unpredictable +number of output files. + +actool only runs on Darwin, so actoolwrapper only runs on Darwin. + diff --git a/src/tools/xcode/actoolwrapper/actoolwrapper.sh b/src/tools/xcode/actoolwrapper/actoolwrapper.sh new file mode 100755 index 0000000000..7191583b94 --- /dev/null +++ b/src/tools/xcode/actoolwrapper/actoolwrapper.sh @@ -0,0 +1,71 @@ +#!/bin/bash +# Copyright 2015 Google Inc. All rights reserved. +# +# 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. +# +# actoolwrapper runs actool and zips up the output. +# This script only runs on darwin and you must have Xcode installed. +# +# $1 OUTZIP - the path to place the output zip file. + +set -eu + +OUTZIP=$(tools/objc/realpath "$1") +shift 1 +TEMPDIR=$(mktemp -d -t ZippingOutput) +trap "rm -rf \"$TEMPDIR\"" EXIT + +# actool needs to have absolute paths sent to it, so we call realpaths on +# on all arguments seeing if we can expand them. +# actool and ibtool appear to depend on the same code base. +# --output-partial-info-plist gives actool real troubles +# so we create a file where we expect the plist to be so we can get a full +# path to it. +# Radar 21045660 ibtool has difficulty dealing with relative paths. +TOOLARGS=() +LASTARG="" +for i in $@; do + if [ "$LASTARG" = "--output-partial-info-plist" ]; then + PARENTDIR=$(dirname "$i") + mkdir -p "$PARENTDIR" + touch "$i" + fi + if [ -e "$i" ]; then + TOOLARGS+=($(tools/objc/realpath "$i")) + else + TOOLARGS+=("$i") + fi + LASTARG="$i" +done + +# If we are running into problems figuring out actool issues, there are a couple +# of env variables that may help. Both of the following must be set to work. +# IBToolDebugLogFile=<OUTPUT FILE PATH> +# IBToolDebugLogLevel=4 +# you may also see if +# IBToolNeverDeque=1 +# helps. +# Yes IBTOOL appears to be correct here due to actool and ibtool being based +# on the same codebase. +/usr/bin/xcrun actool --errors --warnings --notices \ + --compress-pngs --output-format human-readable-text \ + --compile "$TEMPDIR" "${TOOLARGS[@]}" + +# Need to push/pop tempdir so it isn't the current working directory +# when we remove it via the EXIT trap. +pushd "$TEMPDIR" > /dev/null +# Reset all dates to Unix Epoch so that two identical zips created at different +# times appear the exact same for comparison purposes. +find . -exec touch -h -t 197001010000 {} \; +zip --symlinks --recurse-paths --quiet "$OUTZIP" . +popd > /dev/null diff --git a/src/tools/xcode/ibtoolwrapper/ibtoolwrapper.sh b/src/tools/xcode/ibtoolwrapper/ibtoolwrapper.sh index 7cc4be3201..968e0bb5c0 100755 --- a/src/tools/xcode/ibtoolwrapper/ibtoolwrapper.sh +++ b/src/tools/xcode/ibtoolwrapper/ibtoolwrapper.sh @@ -29,6 +29,7 @@ ARCHIVEROOT="$2" shift 2 TEMPDIR=$(mktemp -d -t ZippingOutput) trap "rm -rf \"$TEMPDIR\"" EXIT + FULLPATH="$TEMPDIR/$ARCHIVEROOT" PARENTDIR=$(dirname "$FULLPATH") mkdir -p "$PARENTDIR" @@ -37,12 +38,12 @@ FULLPATH=$(tools/objc/realpath "$FULLPATH") # IBTool needs to have absolute paths sent to it, so we call realpaths on # on all arguments seeing if we can expand them. # Radar 21045660 ibtool has difficulty dealing with relative paths. -IBTOOLARGS=() +TOOLARGS=() for i in $@; do if [ -e "$i" ]; then - IBTOOLARGS+=($(tools/objc/realpath "$i")) + TOOLARGS+=($(tools/objc/realpath "$i")) else - IBTOOLARGS+=($i) + TOOLARGS+=("$i") fi done @@ -55,10 +56,13 @@ done # helps. /usr/bin/xcrun ibtool --errors --warnings --notices \ --auto-activate-custom-fonts --output-format human-readable-text \ - --compile "$FULLPATH" ${IBTOOLARGS[@]} + --compile "$FULLPATH" "${TOOLARGS[@]}" # Need to push/pop tempdir so it isn't the current working directory # when we remove it via the EXIT trap. pushd "$TEMPDIR" > /dev/null -zip -y -r -q "$OUTZIP" . +# Reset all dates to Unix Epoch so that two identical zips created at different +# times appear the exact same for comparison purposes. +find . -exec touch -h -t 197001010000 {} \; +zip --symlinks --recurse-paths --quiet "$OUTZIP" . popd > /dev/null diff --git a/src/tools/xcode/momcwrapper/BUILD b/src/tools/xcode/momcwrapper/BUILD new file mode 100644 index 0000000000..61acf80960 --- /dev/null +++ b/src/tools/xcode/momcwrapper/BUILD @@ -0,0 +1,12 @@ +package(default_visibility = ["//src/test:__subpackages__"]) + +filegroup( + name = "srcs", + srcs = glob(["**"]), +) + +sh_binary( + name = "momcwrapper", + srcs = ["momcwrapper.sh"], + data = ["//src/tools/xcode/realpath:realpath_genrule"], +) diff --git a/src/tools/xcode/momcwrapper/README b/src/tools/xcode/momcwrapper/README new file mode 100644 index 0000000000..37654de429 --- /dev/null +++ b/src/tools/xcode/momcwrapper/README @@ -0,0 +1,6 @@ +momcwrapper runs momc, which compiles xcdatamodels. +momcwrapper then zips up the output, because momc returns an unpredictable +number of output files. + +momc only runs on Darwin, so momcwrapper only runs on Darwin. + diff --git a/src/tools/xcode/momcwrapper/momcwrapper.sh b/src/tools/xcode/momcwrapper/momcwrapper.sh new file mode 100755 index 0000000000..5523a3fdcc --- /dev/null +++ b/src/tools/xcode/momcwrapper/momcwrapper.sh @@ -0,0 +1,38 @@ +#!/bin/bash +# Copyright 2015 Google Inc. All rights reserved. +# +# 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. +# +# momcwrapper runs momc and zips up the output. +# This script only runs on darwin and you must have Xcode installed. +# +# $1 OUTZIP - the path to place the output zip file. + + +set -eu + +OUTZIP=$(tools/objc/realpath "$1") +shift 1 +TEMPDIR=$(mktemp -d -t ZippingOutput) +trap "rm -rf \"$TEMPDIR\"" EXIT + +/usr/bin/xcrun momc "$@" "$TEMPDIR" + +# Need to push/pop tempdir so it isn't the current working directory +# when we remove it via the EXIT trap. +pushd "$TEMPDIR" > /dev/null +# Reset all dates to Unix Epoch so that two identical zips created at different +# times appear the exact same for comparison purposes. +find . -exec touch -h -t 197001010000 {} \; +zip --symlinks --recurse-paths "$OUTZIP" . +popd > /dev/null diff --git a/src/tools/xcode/swiftstdlibtoolwrapper/BUILD b/src/tools/xcode/swiftstdlibtoolwrapper/BUILD new file mode 100644 index 0000000000..1a98848a4b --- /dev/null +++ b/src/tools/xcode/swiftstdlibtoolwrapper/BUILD @@ -0,0 +1,12 @@ +package(default_visibility = ["//src/test:__subpackages__"]) + +filegroup( + name = "srcs", + srcs = glob(["**"]), +) + +sh_binary( + name = "swiftstdlibtoolwrapper", + srcs = ["swiftstdlibtoolwrapper.sh"], + data = ["//src/tools/xcode/realpath:realpath_genrule"], +) diff --git a/src/tools/xcode/swiftstdlibtoolwrapper/README b/src/tools/xcode/swiftstdlibtoolwrapper/README new file mode 100644 index 0000000000..e99ff4ed02 --- /dev/null +++ b/src/tools/xcode/swiftstdlibtoolwrapper/README @@ -0,0 +1,6 @@ +swiftstdlibtoolwrapper runs swift-stdlib-tool, which scans executables and +copies required Swift framework dylibs to the specified path, then zips up +the output for further bundle merging. + +swift-stdlib-tool only runs on Darwin, so swiftstdlibtoolwrapper only runs on +Darwin. diff --git a/src/tools/xcode/swiftstdlibtoolwrapper/swiftstdlibtoolwrapper.sh b/src/tools/xcode/swiftstdlibtoolwrapper/swiftstdlibtoolwrapper.sh new file mode 100755 index 0000000000..f036b93e17 --- /dev/null +++ b/src/tools/xcode/swiftstdlibtoolwrapper/swiftstdlibtoolwrapper.sh @@ -0,0 +1,39 @@ +#!/bin/bash +# Copyright 2015 Google Inc. All rights reserved. +# +# 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. +# +# swiftstdlibtoolwrapper runs swift-stdlib-tool and zips up the output. +# This script only runs on darwin and you must have Xcode installed. +# +# $1 OUTZIP - the path to place the output zip file. + +set -eu + +OUTZIP=$(tools/objc/realpath "$1") +shift 1 +TEMPDIR=$(mktemp -d -t ZippingOutput) +trap "rm -rf \"$TEMPDIR\"" EXIT + +FULLPATH="$TEMPDIR/Frameworks" + +/usr/bin/xcrun swift-stdlib-tool --copy --verbose --destination "$FULLPATH" "$@" + +# Need to push/pop tempdir so it isn't the current working directory +# when we remove it via the EXIT trap. +pushd "$TEMPDIR" > /dev/null +# Reset all dates to Unix Epoch so that two identical zips created at different +# times appear the exact same for comparison purposes. +find . -exec touch -h -t 197001010000 {} \; +zip --symlinks --recurse-paths --quiet "$OUTZIP" . +popd > /dev/null |