...originally probably replaced an en-dash (thanks Roman Eisele).
[LibreOffice.git] / download
blobded21afc9d2fde06a0aaed9d2e58468cb299589d
1 #!/bin/sh
2 #*************************************************************************
4 # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 #
6 # Copyright 2000, 2010 Oracle and/or its affiliates.
8 # OpenOffice.org - a multi-platform office productivity suite
10 # This file is part of OpenOffice.org.
12 # OpenOffice.org is free software: you can redistribute it and/or modify
13 # it under the terms of the GNU Lesser General Public License version 3
14 # only, as published by the Free Software Foundation.
16 # OpenOffice.org is distributed in the hope that it will be useful,
17 # but WITHOUT ANY WARRANTY; without even the implied warranty of
18 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 # GNU Lesser General Public License version 3 for more details
20 # (a copy is included in the LICENSE file that accompanied this code).
22 # You should have received a copy of the GNU Lesser General Public License
23 # version 3 along with OpenOffice.org. If not, see
24 # <http://www.openoffice.org/license.html>
25 # for a copy of the LGPLv3 License.
27 #*************************************************************************
29 # environment setup yet?
30 if [ -z "$TARFILE_LOCATION" ]; then
31 . ./Env.Host.sh
34 # we want to clone if we are in the bootstrap git repo and clone does not exist yet
35 # we need to test for a .git in order not to clone after rsync if we are called in
36 # the inner autogen of the buid-repo based build
38 check_file()
40 echo "Looking for $1 ..."
41 if test -f $1; then
42 echo "ok"
43 else
44 echo "missing required archive; run './download' again";
45 exit 1;
49 if [ -d .git ] ; then
50 if [ -z "$GIT_LINK_SRC" ]; then
51 ./g -f clone
52 else
53 # space-saving clone from another local workdir
54 mkdir clone
55 for i in $GIT_REPO_NAMES ; do
56 bin/git-new-workdir $GIT_LINK_SRC/$i clone/$i
57 for d in clone/$i/* ; do
58 if [ "${d}" != "clone/$i/git-hooks" ]; then
59 ln -sfn ${d} $(basename ${d})
61 done
62 done
66 if [ ! -d "$TARFILE_LOCATION" ]; then
67 mkdir $TARFILE_LOCATION
69 if [ ! -d "$TARFILE_LOCATION" ]; then
70 echo "Error: Cannot create $TARFILE_LOCATION."
71 exit 1
74 FILELIST="$1"
75 if [ -z "$FILELIST" ]; then
76 echo "No filelist provided, using the default ooo.lst."
77 FILELIST="ooo.lst"
80 # check for wget and md5sum
81 wget=
82 md5sum=
83 curl=`which curl 2>/dev/null`
85 for i in wget /usr/bin/wget /usr/local/bin/wget /usr/sfw/bin/wget /opt/sfw/bin/wget /opt/local/bin/wget; do
86 eval "$i --version" > /dev/null 2>&1
87 ret=$?
88 if [ $ret -eq 0 ]; then
89 wget=$i
90 break
92 done
94 if [ -z "$wget" -a -z "$curl" ]; then
95 echo "ERROR: neither wget nor curl found!"
96 exit 1
99 for i in md5 md5sum /usr/local/bin/md5sum gmd5sum /usr/sfw/bin/md5sum /opt/sfw/bin/gmd5sum /opt/local/bin/md5sum; do
100 if [ "$i" = "md5" ]; then
101 eval "$i -x" > /dev/null 2>&1
102 else
103 eval "$i --version" > /dev/null 2>&1
105 ret=$?
106 if [ $ret -eq 0 ]; then
107 md5sum=$i
108 break
110 done
112 if [ "$md5sum" = "md5" ]; then
113 if md5 -r < /dev/null > /dev/null 2>/dev/null; then
114 md5special=-r
115 elif md5 -n < /dev/null > /dev/null 2>/dev/null; then
116 md5special=-n
120 if [ -z "$md5sum" ]; then
121 echo "Warning: no md5sum: found!"
124 start_dir=`pwd`
125 logfile=$TARFILE_LOCATION/fetch.log
126 date >> $logfile
128 downloaditem()
130 if [ "$1" != "" ]; then
131 if [ ! -f "../$2" ]; then
132 echo $2
133 if [ ! -z "$wget" ]; then
134 $wget --progress=dot:mega -N $1/$2 2>&1 | tee -a $logfile
135 else
136 echo fetching $2
137 $curl $file_date_check -O $1/$2 2>&1 | tee -a $logfile
139 wret=$?
140 if [ $wret -ne 0 ]; then
141 mv $2 ${i}_broken
142 failed="$failed $2"
143 wret=0
145 if [ -f $2 -a -n "$3" -a -n "$md5sum" ]; then
146 sum=`$md5sum $md5special $2 | sed "s/ .*//"`
147 if [ "$sum" != "$3" ]; then
148 echo checksum failure for $2 2>&1 | tee -a $logfile
149 failed="$failed $2"
150 mv $2 ${i}_broken
151 else
152 mv $2 ..
154 else
155 mv $2 ..
161 filelist=`cat $FILELIST`
162 mkdir -p $TARFILE_LOCATION/tmp
163 cd $TARFILE_LOCATION/tmp
164 echo $$ > fetch-running
165 for i in $filelist ; do
166 # echo $i
167 if [ "$i" != `echo $i | sed "s/^http:\///"` ]; then
168 tarurl=$i
169 # TODO: check for comment
170 else
171 if [ "$tarurl" != "" ]; then
172 sum=`echo $i | sed "s/-.*//"`
173 downloaditem $tarurl $i $sum
176 done
178 if [ "$COM" = "MSC" ]; then
179 downloaditem "http://download.microsoft.com/download/platformsdk/Redist/5.0.2195.1/W9XNT4/EN-US/" "dbghinst.EXE" "096f1d53d9ba09cde27d6f7c2ea6cc47"
180 downloaditem "http://download.microsoft.com/download/a/b/c/abc45517-97a0-4cee-a362-1957be2f24e1/" "WindowsXP-KB975337-x86-ENU.exe" "946d00d87e4094f3a6e425e2d538eadd"
182 msvcver=`$SRC_ROOT/oowintool --msvc-ver`
183 case "$msvcver" in
184 9.0)
185 downloaditem "http://download.microsoft.com/download/5/D/8/5D8C65CB-C849-4025-8E95-C3966CAFD8AE/" "vcredist_x86.exe" "35da2bf2befd998980a495b6f4f55e60"
186 downloaditem "http://download.microsoft.com/download/5/D/8/5D8C65CB-C849-4025-8E95-C3966CAFD8AE/" "vcredist_x64.exe" "e2ada570911edaaae7d1b3c979345fce"
190 esac
194 if [ -f $start_dir/bootstrap.ver -a ! -d $start_dir/.git ] ; then
195 # bootstrap is from sources, so get the other source tarballs
196 . $start_dir/bootstrap.ver
197 lo_src_dir="$start_dir/src"
198 mkdir -p "$lo_src_dir"
199 for piece in `cat $start_dir/bin/repo-list` ; do
200 tarname="libreoffice-$piece-$lo_bootstrap_ver"
201 if [ ! -f "$TARFILE_LOCATION/$tarname.tar.bz2" ] ; then
202 downloaditem "http://download.documentfoundation.org/libreoffice/src/" "$tarname.tar.bz2" ""
204 $start_dir/bin/unpack-sources $start_dir $TARFILE_LOCATION/$tarname.tar.bz2
205 done
208 rm $TARFILE_LOCATION/tmp/*-*
209 cd $start_dir
211 if [ ! -z "$failed" ]; then
212 echo
213 echo ERROR: failed on:
214 for i in $failed ; do
215 echo $i
216 done
217 exit 1
220 if [ "$COM" = "MSC" -a -n "$md5sum" ]; then
221 # This can be run only on Windows itself (Cygwin)
222 TMPUNPACK=`cygpath -d $TARFILE_LOCATION/tmp`
223 chmod a+w $TARFILE_LOCATION/tmp
224 if [ ! -f ./external/dbghelp/dbghelp.dll -a -f $TARFILE_LOCATION/dbghinst.EXE ]; then
225 if [ ! -x $TARFILE_LOCATION/dbghinst.EXE ]; then
226 chmod +x $TARFILE_LOCATION/dbghinst.EXE
228 $TARFILE_LOCATION/dbghinst.EXE /T:$TMPUNPACK /C
229 sum=`$md5sum $md5special $TARFILE_LOCATION/tmp/dbghelp.exe | sed "s/ .*//"`
230 if [ "$sum" = "cd3086a91e37965dd761ef5fd5df5b15" ]; then
231 unzip -LL -j -o -d ./external/dbghelp $TARFILE_LOCATION/tmp/dbghelp.exe
234 if [ ! -f ./external/gdiplus/gdiplus.dll -a -f $TARFILE_LOCATION/WindowsXP-KB975337-x86-ENU.exe ]; then
235 gdiplus_dll_path=asms/10/msft/windows/gdiplus/gdiplus.dll
237 # Run it through cmd so that the UAC prompt is displayed
238 echo
239 echo "NOTE: We are running the Microsoft KB975337 security fix installer"
240 echo "to get gdiplus.dll. You will most probably get a UAC prompt now."
241 echo "If you trust us, just enter your administrator password."
242 echo "The security fix is run with the /extract switch to just unpack"
243 echo "its files."
244 echo "If you don't trust us, just get gdiplus.dll yourself and put it"
245 echo "in external/gdiplus/gdiplus.dll."
246 echo "gdiplus.dll is included in the LibreOffice installer for the benefit of"
247 echo "Windows 2000 users."
248 # A few empty lines so that the above is visible even if the taskbar's auto-hide is turned on,
249 # and the UAC prompt caused it to taise (with a blinking icon for the UAC prompt)
250 echo
251 echo
252 echo
253 cmd /c "`cygpath -d $TARFILE_LOCATION/WindowsXP-KB975337-x86-ENU.exe` /extract:$TMPUNPACK /q"
254 if [ -f $TARFILE_LOCATION/tmp/$gdiplus_dll_path ]; then
255 echo "Extraction succeeded"
256 sum=`$md5sum $md5special $TARFILE_LOCATION/tmp/$gdiplus_dll_path | sed "s/ .*//"`
257 if [ "$sum" = "4721ab485e0c29cd1617a5f296b9cc47" ]; then
258 cp $TARFILE_LOCATION/tmp/$gdiplus_dll_path ./external/gdiplus/gdiplus.dll
259 else
260 echo "But unexpected checksum of $gdiplus_dll_path"
262 else
263 echo "WindowsXP-KB975337-x86-ENU.exe did not unpack the expected $gdiplus_dll_path"
266 if [ ! -f ./external/vcredist/vcredist_x86.exe -a -f $TARFILE_LOCATION/vcredist_x86.exe ]; then
267 cp $TARFILE_LOCATION/vcredist_x86.exe ./external/vcredist/vcredist_x86.exe
269 if [ ! -f ./external/vcredist/vcredist_x64.exe -a -f $TARFILE_LOCATION/vcredist_x64.exe ]; then
270 cp $TARFILE_LOCATION/vcredist_x64.exe ./external/vcredist/vcredist_x64.exe
274 # OxygenOffice extras
275 for pack in $OOOP_FONTS_PACK $OOOP_GALLERY_PACK $OOOP_SAMPLES_PACK $OOOP_TEMPLATES_PACK ; do
276 check_file $TARFILE_LOCATION/$pack
277 echo "Unpacking OxygenOffice extra '$pack' ..."
278 unzip -o -q $TARFILE_LOCATION/$pack -d $SRC_ROOT/extras/source
279 done
281 # Extensions copy
282 for pack in $BARCODE_EXTENSION_PACK $DIAGRAM_EXTENSION_PACK $VALIDATOR_EXTENSION_PACK $WATCH_WINDOW_EXTENSION_PACK $NUMBERTEXT_EXTENSION_PACK $HUNART_EXTENSION_PACK $TYPO_EXTENSION_PACK $GOOGLE_DOCS_EXTENSION_PACK $OOOBLOGGER_EXTENSION_PACK $LIGHTPROOF_HU_PACK $LIGHTPROOF_RU_PACK $LIGHTPROOF_EN_US_PACK $SUNTEMPLATES_DE_PACK $SUNTEMPLATES_EN_US_PACK $SUNTEMPLATES_ES_PACK $SUNTEMPLATES_FR_PACK $SUNTEMPLATES_HU_PACK $SUNTEMPLATES_IT_PACK; do
283 check_file $TARFILE_LOCATION/$pack
284 packfilename=`echo "$pack" | cut -f 2- -s -d - | cut -f 1 -d _`
285 echo "Copy extension: '$pack' as '$packfilename.oxt' ..."
286 mkdir -p $SRC_ROOT/extras/source/extensions/ || exit 1
287 cp $TARFILE_LOCATION/$pack $SRC_ROOT/extras/source/extensions/$packfilename.oxt || exit 1
288 done
290 [ -x "post_download" ] || { echo "'post_download' script not found, run ./autogen.sh." ; exit 1 ; }
292 # Save the config.log from the main configure script
293 # and restore it after running post_download.
294 mv config.log config.log.save
296 ./post_download --build=$BUILD_PLATFORM --host=$HOST_PLATFORM
297 post_download_status=$?
299 test -f config.log && mv config.log post_download.log
300 mv config.log.save config.log
302 exit $post_download_status
304 # Local Variables:
305 # tab-width: 4
306 # indent-tabs-mode: nil
307 # End:
309 # vim:set shiftwidth=4 softtabstop=4 expandtab: