X-Git-Url: http://git.megacz.com/?p=ghc-hetmet.git;a=blobdiff_plain;f=distrib%2Fprep-bin-dist-mingw;h=957030a3f476d413cadf2f765d3b8db4a1b32681;hp=924b1c404aa227910725ddf31cc4b1adb970b1b7;hb=f30908b63b7bda01ac4fc8a3a62ea2a23da01ae9;hpb=d89f0e2d2adf5ebce15984d08b1d00de60db6d78 diff --git a/distrib/prep-bin-dist-mingw b/distrib/prep-bin-dist-mingw index 924b1c4..957030a 100644 --- a/distrib/prep-bin-dist-mingw +++ b/distrib/prep-bin-dist-mingw @@ -1,22 +1,61 @@ #!/bin/sh # -# Running 'binary-dist' gives us a tree which -# isn't quite right for the purposes of creating -# a mingw/win32 install tree. This script rejigs -# the tree. +# Running 'binary-dist' gives us a tree which isn't quite right +# for the purposes of creating a mingw/win32 install tree. +# This script rejigs that tree. The resulting tree is ready for +# packaging up in whatever form convenient (MSI installer / tar bundle/ ..) # # To use: # # foo$ cd -# foo$ make binary-dist Project=Ghc +# foo$ make binary-dist Project=Ghc (*) # foo$ cd ghc- # foo$ ../distrib/prep-bin-dist-mingw # -export gcc_lib=c:/ghc/ghc-5.02.2/gcc-lib -export perl_dir=c:/ghc/ghc-5.02.2 -export mingw_include=c:/ghc/ghc-5.02.2/include/mingw +# * - making sure you've initially set BIN_DIST=1 in +# your build.mk ... +# +# User tweakables +# (settable via environment variables, e.g., +# mingw_top= ../distrib/prep-bin-dist-mingw +# ) +# +# - mingw_top -- location of mingw distribution tree +# - old_ghc_top -- top of existing GHC binary diste tree +# (needed just to copy along perl binary.) +# +# - gcc_version -- what gcc version your mingw tree uses. +# +# +if [ "x${old_ghc_top}" == "x" ]; then + export old_ghc_top=c:/ghc/ghc-6.2.1 +fi +if [ "x${mingw_top}" == "x" ]; then + export mingw_top=c:/mingw3 +fi -# Play safe +# The gcc-lib directory of the mingw tree you want to +# include with the binary dist. +if [ "x${gcc_version}" == "x" ]; then + # The default (with mingw3) + export gcc_lib=$mingw_top/lib/gcc-lib/mingw32/3.2.3 +else + export gcc_lib=$mingw_top/lib/gcc-lib/mingw32/${gcc_version} +fi + +#Directory where a (cygwin-free) perl binary resides. +export perl_dir=$old_ghc_top + +# +# The mingw include, lib, and bin directories; all derived +# from ${mingw_top}. +# +export mingw_include=$mingw_top/include +export mingw_lib=$mingw_top/lib +export mingw_bin=$mingw_top/bin + +# Check that we're in an OK place before starting to re-org +# the directory tree.. if ! [ -d bin/i386-unknown-mingw32 ] ; then echo "Doesn't look as if I'm in the toplevel directory of a mingw tree" echo "Usage: cd ghc- ; ../distrib/prep-bin-dist-mingw" @@ -24,8 +63,9 @@ if ! [ -d bin/i386-unknown-mingw32 ] ; then fi; echo "Removing configure script files...not needed" -rm -f config.guess config.sub configure configure.in mkdirhier +rm -f config.guess config.sub configure configure.ac mkdirhier rm -f Makefile-bin.in Makefile.in aclocal.m4 install-sh +rm -rf autom4te.cache echo "rejig bin/" mv bin/i386-unknown-mingw32/* bin/ @@ -39,18 +79,49 @@ rmdir lib mv ghc-asm.prl ghc-asm mv ghc-split.prl ghc-split -echo "copy in gcc-lib/" -cp -Rf $gcc_lib . +echo "create gcc-lib/" +# +# A bunch of stuff gets lumped into gcc-lib: +# +# - the gcc-lib/ + gcc-lib/include of the gcc you +# intend to ship (normally located as +# lib/gcc-lib/mingw// in your mingw tree.) +# - the contents of mingw/lib/ +# - ld.exe, as.exe, dlltool.exe, dllwrap.exe from mingw/bin +# to gcc-lib/ +# - ar.exe from mingw/bin to bin/ +# +mkdir gcc-lib +mkdir gcc-lib/include +cp $gcc_lib/* gcc-lib/ +cp $gcc_lib/include/* gcc-lib/include/ +cp $mingw_lib/* gcc-lib/ +cp $mingw_bin/as.exe gcc-lib/ +cp $mingw_bin/ld.exe gcc-lib/ +cp $mingw_bin/ar.exe bin/ +# Note: later versions of dlltool.exe depend on a bfd helper DLL. +cp $mingw_bin/dllwrap.exe gcc-lib/ +cp $mingw_bin/dlltool.exe gcc-lib/ +rm gcc-lib/f771.exe || echo "good - f771.exe not found" echo "extra header files inside of include/" +# +# contains mingw/include mkdir include/mingw -cp -Rf $mingw_include include/ +cp -Rf $mingw_include/* include/mingw +# +# g++-3/ subdir causes problems with installer tool (+ being a +# troublesome character); leave out for now. +#rm -rf include/mingw/g++-3/ || echo "g++-3/ not there" +rm -rf include/mingw/c++/ || echo "c++/ not there" +echo "add gcc" +cp ${mingw_bin}/gcc.exe . +#cp ${mingw_bin}/gcc-2.exe gcc.exe echo "copy in perl too" cp ${perl_dir}/perl.exe . cp ${perl_dir}/perl56.dll . -cp ${perl_dir}/gcc.exe . # For reasons unknown, duplicate copies of misc package files in share/ # (leave them be for now.) @@ -58,12 +129,9 @@ cp ${perl_dir}/gcc.exe . echo "formatting documentation" cp README README.txt mv share doc -cp ../ghc/docs/users_guide/users_guide.pdf doc/ -cp ../hslibs/doc/hslibs.pdf doc/ -#mkdir doc -#mkdir doc/user-guide -#cp -Rf html/* doc/user-guide/ -#cp pdf/set.pdf doc/ -#rm -rf html/ -#rm -rf pdf/ - +cp ../ghc/docs/users_guide/users_guide.pdf doc/ || + (make -C ../ghc/docs/users_guide/ pdf ; cp ../ghc/docs/users_guide/users_guide.pdf doc/) || + echo "No User Guide PDF doc found" +cp ../hslibs/doc/hslibs.pdf doc/ || + (make -C ../hslibs/doc/ pdf ; cp ../hslibs/doc/hslibs.pdf doc/) || + echo "No HSLIBS PDF doc found"