]> spindle.queued.net Git - midori/commitdiff
Merging dll-recursive.sh into makedist.midori.
authorPeter de Ridder <peter@xfce.org>
Sun, 17 Jul 2011 16:14:43 +0000 (18:14 +0200)
committerChristian Dywan <christian@twotoasts.de>
Tue, 19 Jul 2011 19:16:24 +0000 (21:16 +0200)
This will make makedist.midori self-contained. And doesn't require
dll-recursive.sh to be in the current working directory.

win32/makedist/dll-recursive.sh [deleted file]
win32/makedist/makedist.midori

diff --git a/win32/makedist/dll-recursive.sh b/win32/makedist/dll-recursive.sh
deleted file mode 100755 (executable)
index 9442490..0000000
+++ /dev/null
@@ -1,31 +0,0 @@
-#! /bin/sh
-
-# Copyright (C) 2010-2011 Peter de Ridder <peter@xfce.org>
-#
-# This library is free software; you can redistribute it and/or
-# modify it under the terms of the GNU Lesser General Public
-# License as published by the Free Software Foundation; either
-# version 2.1 of the License, or (at your option) any later version.
-#
-# See the file COPYING for the full license text.
-
-temp_file_new=`mktemp`
-temp_file_old=`mktemp`
-
-while [ "$1" ]
-do
-  echo $1 >> $temp_file_new
-  shift
-done
-
-while [ "x`sha1sum - < $temp_file_new`" != "x`sha1sum - < $temp_file_old`" ]
-do
-  files=`cat $temp_file_new $temp_file_old | sort | uniq -u`
-  cp $temp_file_new $temp_file_old
-  strings $files 2> /dev/null | grep \\.dll | cat - $temp_file_old | sort | uniq > $temp_file_new
-done
-
-cat $temp_file_new
-
-rm $temp_file_new $temp_file_old
-
index e9732c850115700a05bb75d77dd98d8bc0d9cf26..d842a85ef588bd6c7be5d21217b0bb95393956ae 100755 (executable)
@@ -9,15 +9,60 @@
 #
 # See the file COPYING for the full license text.
 
+# script: makedist.midori [version tag]
+#
+# This script creates an archive containing all required files for
+# midori on windows.  The midori version is inserted in the name of
+# the archive and appended to the name of the root directory in the
+# archive.
+# The name of the archive is contructed as follows:
+# midori<version tag>-<timestamp>.extension
+# The archive contains a root directory named:
+# midori<version tag>
+
 # a bit of configuration
 root_dir=$MINGW_PREFIX
-script_dir=$PWD
 
 # create temporary working directory
 temp_dir=`mktemp -d`
 
+# check if we can use 7zip
+have_7zip=`which 7za`
+
 # generate unique filename
-ARCHIVE=midori$1-`date +%Y%m%d%H%M`.zip
+if [ "$have_7zip" != ""  ]; then
+    ARCHIVE=midori$1-`date +%Y%m%d%H%M`.7z
+else
+    ARCHIVE=midori$1-`date +%Y%m%d%H%M`.zip
+fi
+
+# function: dll-recursive <list of exe and dll files ...>
+#
+# recursively search all dll dependencies of the input files.
+# The resulting list of dll files including the input files is
+# printed to stdout.
+dll_recursive ()
+{
+  temp_file_new=`mktemp`
+  temp_file_old=`mktemp`
+
+  while [ "$1" ]
+  do
+    echo $1 >> $temp_file_new
+    shift
+  done
+
+  while [ "x`sha1sum - < $temp_file_new`" != "x`sha1sum - < $temp_file_old`" ]
+  do
+    files=`cat $temp_file_new $temp_file_old | sort | uniq -u`
+    cp $temp_file_new $temp_file_old
+    strings $files 2> /dev/null | grep \\.dll | cat - $temp_file_old | sort | uniq > $temp_file_new
+  done
+
+  cat $temp_file_new
+
+  rm $temp_file_new $temp_file_old
+}
 
 echo -n "Creating $ARCHIVE ."
 
@@ -28,7 +73,7 @@ echo -n .
 
 # auto generate dll list, only of existing files
 pushd $root_dir/bin > /dev/null
-$script_dir/dll-recursive.sh midori*.exe gspawn-*-helper*.exe libhunspell*.dll > $temp_dir/midori.exe.lst
+dll_recursive midori*.exe gspawn-*-helper*.exe libhunspell*.dll > $temp_dir/midori.exe.lst
 files=`ls | cat - $temp_dir/midori.exe.lst | sort | uniq -d`
 rm $temp_dir/midori.exe.lst
 popd > /dev/null
@@ -82,9 +127,13 @@ echo -n .
 
 ARCHIVE=`pwd`/$ARCHIVE
 
-# store as tar.bz2 file
+# store as zip/7z file
 pushd $temp_dir > /dev/null
-zip -rq $ARCHIVE midori$1
+if [ "$have_7zip" != "" ]; then
+    7za a -m0=lzma -mx=9 $ARCHIVE midori$1
+else
+    zip -rq $ARCHIVE midori$1
+fi
 popd > /dev/null
 
 echo -n .