diff options
author | Ian Lynagh <igloo@earth.li> | 2007-05-29 10:21:43 +0000 |
---|---|---|
committer | Ian Lynagh <igloo@earth.li> | 2007-05-29 10:21:43 +0000 |
commit | a12dcc89780ddec69beec723ac444c5fab388a9a (patch) | |
tree | 55c5e94c16313635f3c2a58d9d0064cfc58586a2 | |
parent | 1a470c9404950cc6737853309d35798a98ad0c30 (diff) | |
download | haskell-a12dcc89780ddec69beec723ac444c5fab388a9a.tar.gz |
Build Windows installer when making a bindist if ISCC is set
It doesn't work yet, but I'm pretty sure that's because the bindist is
broken rather than the installer is broken.
-rw-r--r-- | Makefile | 31 | ||||
-rw-r--r-- | distrib/ghc.iss | 77 | ||||
-rw-r--r-- | distrib/hsicon.ico | bin | 0 -> 2734 bytes | |||
-rw-r--r-- | mk/config.mk.in | 4 |
4 files changed, 109 insertions, 3 deletions
@@ -291,6 +291,13 @@ binary-dist:: @echo "Generating a shippable configure script.." $(MV) $(BIN_DIST_DIR)/configure-bin.ac $(BIN_DIST_DIR)/configure.ac ( cd $(BIN_DIST_DIR); autoconf ) + +ifeq "$(TARGETPLATFORM)" "i386-unknown-mingw32" +binary-dist:: + $(MKDIRHIER) $(BIN_DIST_DIR)/icons + cp distrib/hsicon.ico $(BIN_DIST_DIR)/icons +endif + # # binary dist'ing the documentation. # The default documentation to build/install is given below; overrideable @@ -394,6 +401,22 @@ tar-binary-dist: ( cd $(BIN_DIST_TOPDIR); tar cf - $(BIN_DIST_NAME) | bzip2 >$(BIN_DIST_TARBALL) ) ( cd $(BIN_DIST_TOPDIR); bunzip2 -c $(BIN_DIST_TARBALL) | tar tf - | sed "s/^ghc-$(ProjectVersion)/fptools/" | sort >bin-manifest-$(ProjectVersion) ) +PUBLISH_FILES = $(BIN_DIST_TARBALL) + +# Upload the distribution and documentation +ifneq "$(ISCC)" "" +WINDOWS_INSTALLER_BASE = ghc-$(ProjectVersion)-$(TARGETPLATFORM) +WINDOWS_INSTALLER = $(WINDOWS_INSTALLER)$(exeext) + +PUBLISH_FILES += $(WINDOWS_INSTALLER) + +binary-dist :: generate-windows-installer + +.PHONY: generate-windows-installer +generate-windows-installer :: + $(SED) "s/@VERSION@/$(ProjectVersion)/" distrib/ghc.iss | $(ISCC) /O. /F$(WINDOWS_INSTALLER_BASE) - +endif + # Upload the distribution and documentation ifneq "$(PublishLocation)" "" binary-dist :: publish-binary-dist @@ -401,9 +424,11 @@ endif .PHONY: publish-binary-dist publish-binary-dist :: - @for i in 0 1 2 3 4 5 6 7 8 9; do \ - echo "Try $$i: $(PublishCp) $(BIN_DIST_TARBALL) $(PublishLocation)/dist"; \ - if $(PublishCp) $(BIN_DIST_TARBALL) $(PublishLocation)/dist; then break; fi; \ + @for f in $(PUBLISH_FILES); do \ + @for i in 0 1 2 3 4 5 6 7 8 9; do \ + echo "Try $$i: $(PublishCp) $$f $(PublishLocation)/dist"; \ + if $(PublishCp) $$f $(PublishLocation)/dist; then break; fi; \ + done \ done ifeq "$(TARGETPLATFORM)" "i386-unknown-mingw32" diff --git a/distrib/ghc.iss b/distrib/ghc.iss new file mode 100644 index 0000000000..dcadd73b5c --- /dev/null +++ b/distrib/ghc.iss @@ -0,0 +1,77 @@ + +[Setup] +AppName=GHC +AppVerName=GHC @VERSION@ +DefaultDirName={sd}\ghc\ghc-@VERSION@ +UsePreviousAppDir=no +DefaultGroupName=GHC +UninstallDisplayIcon={app}\bin\ghci.exe +Compression=lzma +SolidCompression=yes +PrivilegesRequired=none +ChangesAssociations=yes +ChangesEnvironment=yes + + +[Files] +Source: "ghc-@VERSION@\*"; DestDir: "{app}"; Flags: recursesubdirs +Source: "ghc-@VERSION@\README.txt"; DestDir: "{app}"; Flags: isreadme + +[Icons] +Name: "{group}\@VERSION@\GHCi"; Filename: "{app}\bin\ghci.exe" +Name: "{group}\@VERSION@\GHC Documentation"; Filename: "{app}\doc\html\index.html" +Name: "{group}\@VERSION@\GHC Library Documentation"; Filename: "{app}\doc\html\libraries\index.html" +Name: "{group}\@VERSION@\GHC Readme"; Filename: "{app}\README.txt" + +[Registry] +; set up icon associations +; this does _not_ follow the "play nice" proposal +; future version should +Root: HKCR; Subkey: ".hs"; ValueType: string; ValueName: ""; ValueData: "ghc_haskell"; Flags: uninsdeletevalue +Root: HKCR; Subkey: ".lhs"; ValueType: string; ValueName: ""; ValueData: "ghc_haskell"; Flags: uninsdeletevalue +Root: HKCR; Subkey: "ghc_haskell"; ValueType: string; ValueName: ""; ValueData: "Haskell Source File"; Flags: uninsdeletekey +Root: HKCR; Subkey: "ghc_haskell\DefaultIcon"; ValueType: string; ValueName: ""; ValueData: "{app}\icons\hsicon.ico" +Root: HKCR; Subkey: "ghc_haskell\shell\open\command"; ValueType: string; ValueName: ""; ValueData: """{app}\bin\ghci.exe"" ""%1""" + +; these flags were always set in the past, by the installer +; some programs may rely on them to find GHC +Root: HKCU; Subkey: "Software\Haskell\GHC\ghc-@VERSION@"; ValueType: string; ValueName: "InstallDir"; ValueData: "{app}"; Flags: uninsdeletekey +Root: HKCU; Subkey: "Software\Haskell\GHC"; ValueType: string; ValueName: "InstallDir"; ValueData: "{app}"; Flags: uninsdeletevalue + +; set the PATH variable, for both GHC and Cabal +Root: HKCU; Subkey: "Environment"; ValueName: "Path"; ValueType: "string"; ValueData: "{app}\bin;{olddata}"; Check: NotOnPathAlready('{app}\bin'); Flags: preservestringtype +Root: HKCU; Subkey: "Environment"; ValueName: "Path"; ValueType: "string"; ValueData: "{pf}\Haskell\bin;{olddata}"; Check: NotOnPathAlready('{pf}\Haskell\bin'); Flags: preservestringtype + + +; stolen from Gtk2Hs, I'm sure they like us :-) +; @dcoutts++ +[Code] + +function NotOnPathAlready(NewValue : String): Boolean; +var + Path: String; +begin + // Log('Checking if Gtk2Hs\bin dir is already on the %PATH%'); + if RegQueryStringValue(HKEY_CURRENT_USER, 'Environment', 'Path', Path) then + begin // Successfully read the value + // Log('HKCU\Environment\PATH = ' + Path); + NewValue := ExpandConstant(NewValue); + // Log('Looking for Gtk2Hs\bin dir in %PATH%: ' + BinDir + ' in ' + Path); + if Pos(LowerCase(NewValue), Lowercase(Path)) = 0 then + begin + // Log('Did not find Gtk2Hs\bin dir in %PATH% so will add it'); + Result := True; + end + else + begin + // Log('Found Gtk2Hs bin dir in %PATH% so will not add it again'); + Result := False; + end + end + else // The key probably doesn't exist + begin + // Log('Could not access HKCU\Environment\PATH so assume it is ok to add it'); + Result := True; + end; +end; + diff --git a/distrib/hsicon.ico b/distrib/hsicon.ico Binary files differnew file mode 100644 index 0000000000..cd0ec6292f --- /dev/null +++ b/distrib/hsicon.ico diff --git a/mk/config.mk.in b/mk/config.mk.in index ff1b564db2..ae7b743691 100644 --- a/mk/config.mk.in +++ b/mk/config.mk.in @@ -1014,6 +1014,10 @@ UNAME = uname # GTK+ GTK_CONFIG = @GTK_CONFIG@ +# Set this if you want to use Inno Setup to build a Windows installer +# when you make a bindist +ISCC = + #----------------------------------------------------------------------------- # DocBook XML stuff |