]>
Commit | Line | Data |
---|---|---|
e6c6c1d9 | 1 | #!/bin/sh |
ca7aa526 | 2 | set -e |
e6c6c1d9 | 3 | |
dbf2ee91 | 4 | # CHANNEL: any from CHANNELS_URL: stable, beta, dev |
ca7aa526 | 5 | CHANNEL=${1:-beta} |
e6c6c1d9 | 6 | |
95372ebe | 7 | CHANNELS_URL=http://omahaproxy.appspot.com/all |
ca7aa526 | 8 | PACKAGE_NAME=chromium-browser |
f4176835 ER |
9 | PROGRAM=${0##*/} |
10 | WORK_DIR=$(cd "$(dirname "$0")"; pwd) | |
ca7aa526 | 11 | LOCKFILE=$WORK_DIR/$PACKAGE_NAME-$CHANNEL.lock |
71581184 | 12 | # Browse URL: http://gsdview.appspot.com/chromium-browser-official/ |
ca7aa526 | 13 | OFFICIAL_URL=http://commondatastorage.googleapis.com/chromium-browser-official |
39b18362 | 14 | ALT_URL=https://github.com/zcbenz/chromium-source-tarball/releases/download |
ca7aa526 | 15 | DIST_DIR=$HOME/public_html/chromium-browser/src/$CHANNEL |
e6c6c1d9 | 16 | |
eea8ad40 ER |
17 | # skip package build if interactive |
18 | tty -s && build_package=0 | |
19 | ||
71581184 | 20 | VERSION=${2:-$(wget -qO - "$CHANNELS_URL?os=linux&channel=$CHANNEL" | awk -F, 'NR > 1{print $3}')} |
95372ebe ER |
21 | if [ -z "$VERSION" ]; then |
22 | echo >&2 "Can't figure out version for $CHANNEL" | |
23 | exit 1 | |
24 | fi | |
25 | ||
e20f2cd0 | 26 | # don't use .xz for beta channels, annoying if unpacks that slowly |
f20db397 ER |
27 | if [ "$CHANNEL" = "stable" ]; then |
28 | EXT=xz | |
29 | else | |
30 | EXT=gz | |
31 | fi | |
32 | VERSION_FILE=$DIST_DIR/$PACKAGE_NAME-$VERSION.tar.$EXT | |
e6c6c1d9 | 33 | |
5ee7fc97 | 34 | if [ -e $VERSION_FILE -a -z "$FORCE" ]; then |
ca7aa526 ER |
35 | # nothing to update |
36 | exit 0 | |
37 | fi | |
e6c6c1d9 | 38 | |
ca7aa526 | 39 | set -x |
e6c6c1d9 | 40 | |
f4176835 ER |
41 | ( |
42 | flock -n 9 || { echo "$PROGRAM: locked"; exit 1; } | |
e6c6c1d9 | 43 | |
f4176835 ER |
44 | TMP_DIR=$(mktemp -d $WORK_DIR/$PACKAGE_NAME-$CHANNEL-$VERSION-_XXXXXX) |
45 | LOGFILE=$TMP_DIR/$PACKAGE_NAME-$VERSION.log | |
e6c6c1d9 | 46 | |
f4176835 ER |
47 | ( |
48 | cd "$TMP_DIR" | |
9d8fb756 | 49 | srctarball=$PACKAGE_NAME-$VERSION.tar.xz |
39b18362 ER |
50 | wget -nc -nv -O $srctarball "$OFFICIAL_URL/chromium-$VERSION.tar.xz" || : |
51 | wget -nc -nv -O $srctarball "$ALT_URL/$VERSION/chromium-$VERSION.tar.xz" || : | |
52 | test -f $srctarball | |
e6c6c1d9 | 53 | |
f4176835 ER |
54 | # repackage cleaned up tarball |
55 | test -d $PACKAGE_NAME-$VERSION || { | |
56 | tar xvf $srctarball | |
75f96a39 | 57 | mv chromium-$VERSION $PACKAGE_NAME-$VERSION |
f4176835 | 58 | } |
42cc2c8c | 59 | |
f4176835 ER |
60 | ls -lh $srctarball |
61 | rm $srctarball | |
42cc2c8c | 62 | |
75f96a39 | 63 | cd $PACKAGE_NAME-$VERSION |
f4176835 | 64 | du -sh . |
2f77d5e5 | 65 | |
e00e4177 | 66 | awk '/^#define/ && /(MAJOR|MINOR)_VERSION|BUILD_NUMBER|PATCH_LEVEL/ { printf("%s=%s\n", $2, $3) }' v8/src/version.cc | tee -a v8.sh |
2f77d5e5 | 67 | |
b644427e | 68 | if [ "$CHANNEL" = "stable" ]; then |
708e64c2 | 69 | patch -p1 < $WORK_DIR/remove_bundled_libraries-stale.patch |
af13d564 | 70 | sh -x $WORK_DIR/clean-source.sh emptydirs=1 v8=0 mesa=0 sqlite=0 ffmpeg=0 protobuf=0 |
708e64c2 | 71 | patch -p1 -R < $WORK_DIR/remove_bundled_libraries-stale.patch |
f4176835 | 72 | fi |
dbf2ee91 | 73 | |
f4176835 ER |
74 | # do not keep REMOVED*.txt in tarball. they are visible in .log anyway |
75 | rm -vf REMOVED-*.txt | |
07b01cb7 | 76 | |
f4176835 | 77 | du -sh . |
07b01cb7 | 78 | |
f4176835 ER |
79 | # add LASTCHANGE info, take "branch_revision" item |
80 | svnver=$(wget -qO - "$CHANNELS_URL?os=linux&channel=$CHANNEL" | awk -F, 'NR > 1{print $8}') | |
81 | echo "$svnver" > build/LASTCHANGE.in | |
85917d98 | 82 | |
75f96a39 | 83 | cd .. |
85917d98 | 84 | |
f4176835 ER |
85 | tarball=$PACKAGE_NAME-$VERSION.tar.$EXT |
86 | # xz -9 OOM's on carme | |
87 | XZ_OPT=-e8 tar -caf $tarball $PACKAGE_NAME-$VERSION | |
88 | ls -lh $tarball | |
e6c6c1d9 | 89 | |
f4176835 | 90 | rm -rf $PACKAGE_NAME-$VERSION |
e6c6c1d9 | 91 | |
f4176835 ER |
92 | chmod 644 $tarball |
93 | mv $tarball $DIST_DIR | |
e6c6c1d9 | 94 | |
f4176835 | 95 | ) > $LOGFILE 2>&1 |
e6c6c1d9 | 96 | |
f4176835 ER |
97 | chmod 644 $LOGFILE |
98 | mv $LOGFILE $DIST_DIR | |
e6c6c1d9 | 99 | |
f4176835 | 100 | rm -rf $TMP_DIR |
e6c6c1d9 | 101 | |
f4176835 ER |
102 | # create diff patches |
103 | BASEVER=${VERSION%.*}.0 | |
104 | if [ -e $DIST_DIR/$PACKAGE_NAME-$BASEVER.tar.$EXT ]; then | |
105 | base=$(readlink -f $DIST_DIR/$PACKAGE_NAME-$BASEVER.tar.$EXT) | |
106 | current=$DIST_DIR/$PACKAGE_NAME-$VERSION.tar.$EXT | |
e63ffea8 ER |
107 | if [ "$(basename $base)" != "$(basename $current)" ]; then |
108 | sh -x $WORK_DIR/make-diff-patch.sh $base $current | |
ac64eb76 | 109 | chmod 644 $PACKAGE_NAME-$VERSION.patch.xz |
e63ffea8 ER |
110 | mv $PACKAGE_NAME-$VERSION.patch.xz $DIST_DIR |
111 | # for beta and dev channels, update the diff pointer | |
112 | if [ "$CHANNEL" != "stable" ]; then | |
113 | ln -sf $PACKAGE_NAME-$VERSION.tar.$EXT $DIST_DIR/$PACKAGE_NAME-$BASEVER.tar.$EXT | |
114 | fi | |
f4176835 ER |
115 | fi |
116 | fi | |
1a868d2c | 117 | |
f4176835 ER |
118 | # try updating spec and build it as well |
119 | if [ -x $WORK_DIR/update-source.sh ]; then | |
eea8ad40 ER |
120 | build_package=${build_package-1} \ |
121 | publish_packages=${publish_packages-1} \ | |
f4176835 | 122 | sh -x $WORK_DIR/update-source.sh |
ce99e0e3 | 123 | fi |
9337d609 | 124 | |
f4176835 ER |
125 | rm $LOCKFILE |
126 | ) 9>$LOCKFILE |