15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#!/bin/sh
25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)# Copyright (c) 2009 The Chromium Authors. All rights reserved.
45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)# Use of this source code is governed by a BSD-style license that can be
55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)# found in the LICENSE file.
65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)# A simple shell script for creating a chrome zip from an output directory.
85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)# Pass the path to the output directory you wish to package.
95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)if [ $# = 0 ]; then
115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  echo "usage: make_zip.sh path/to/release/dir [output-name]"
125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  exit 1
135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)fi
145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)tools_dir=$(dirname "$0")
165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)release_dir="$1"
175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)files=$(sed -n "s/^ *'filename': '\(.*\)',$/\1/ p" "$tools_dir/FILES.cfg")
195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)output=${2:-chrome-win32}
215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)rm -fr $output $output.zip
225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)mkdir $output
235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)# Get the absolute path of the output directory.  We need it when copying
255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)# files.
265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)output_abs=`cygpath -a $output`
275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)# Use cp --parents to copy full relative directory.  Since we need the
295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)# relative directory for the zip, change into the release dir.
305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)pushd "$release_dir"
315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)# The file names in FILES may contain whitespace, e.g. 'First Run'.
325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)# Change IFS setting so we only split words with '\n'
335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IFS_Default=$IFS
345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IFS=$'\n'
355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)for f in ${files[@]}; do
365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)  cp -r --parents "$f" "$output_abs"
375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)done
385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)IFS=$IFS_Default
395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)popd
405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)
415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)zip -r $output.zip $output
42