use cygwin ldd to find dlls to include, instead of manually listing
This commit is contained in:
parent
6b956c8678
commit
cd4fb498a7
1 changed files with 18 additions and 52 deletions
|
@ -1,7 +1,8 @@
|
||||||
{- Generates a NullSoft installer program for git-annex on Windows.
|
{- Generates a NullSoft installer program for git-annex on Windows.
|
||||||
-
|
-
|
||||||
- To build the installer, git-annex should already be built by cabal,
|
- To build the installer, git-annex should already be built by cabal,
|
||||||
- and ssh and rsync, as well as cygwin libraries, already installed.
|
- and ssh and rsync etc, as well as cygwin libraries, already installed
|
||||||
|
- from cygwin.
|
||||||
-
|
-
|
||||||
- This uses the Haskell nsis package (cabal install nsis)
|
- This uses the Haskell nsis package (cabal install nsis)
|
||||||
- to generate a .nsi file, which is then used to produce
|
- to generate a .nsi file, which is then used to produce
|
||||||
|
@ -11,7 +12,7 @@
|
||||||
- exception of git. The user needs to install git separately,
|
- exception of git. The user needs to install git separately,
|
||||||
- and the installer checks for that.
|
- and the installer checks for that.
|
||||||
-
|
-
|
||||||
- Copyright 2013 Joey Hess <id@joeyh.name>
|
- Copyright 2013-2015 Joey Hess <id@joeyh.name>
|
||||||
-
|
-
|
||||||
- Licensed under the GNU GPL version 3 or higher.
|
- Licensed under the GNU GPL version 3 or higher.
|
||||||
-}
|
-}
|
||||||
|
@ -22,13 +23,17 @@ import Development.NSIS
|
||||||
import System.Directory
|
import System.Directory
|
||||||
import System.FilePath
|
import System.FilePath
|
||||||
import Control.Monad
|
import Control.Monad
|
||||||
|
import Control.Applicative
|
||||||
import Data.String
|
import Data.String
|
||||||
import Data.Maybe
|
import Data.Maybe
|
||||||
|
import Data.Char
|
||||||
|
import Data.List (nub)
|
||||||
|
|
||||||
import Utility.Tmp
|
import Utility.Tmp
|
||||||
import Utility.Path
|
import Utility.Path
|
||||||
import Utility.CopyFile
|
import Utility.CopyFile
|
||||||
import Utility.SafeCommand
|
import Utility.SafeCommand
|
||||||
|
import Utility.Process
|
||||||
import Build.BundledPrograms
|
import Build.BundledPrograms
|
||||||
|
|
||||||
main = do
|
main = do
|
||||||
|
@ -37,17 +42,19 @@ main = do
|
||||||
mustSucceed "ln" [File "dist/build/git-annex/git-annex.exe", File gitannex]
|
mustSucceed "ln" [File "dist/build/git-annex/git-annex.exe", File gitannex]
|
||||||
let license = tmpdir </> licensefile
|
let license = tmpdir </> licensefile
|
||||||
mustSucceed "sh" [Param "-c", Param $ "zcat standalone/licences.gz > '" ++ license ++ "'"]
|
mustSucceed "sh" [Param "-c", Param $ "zcat standalone/licences.gz > '" ++ license ++ "'"]
|
||||||
extrabins <- forM (cygwinPrograms ++ cygwinDlls) $ \f -> do
|
extrabins <- forM (cygwinPrograms) $ \f -> do
|
||||||
p <- searchPath f
|
p <- searchPath f
|
||||||
when (isNothing p) $
|
when (isNothing p) $
|
||||||
print ("unable to find in PATH", f)
|
print ("unable to find in PATH", f)
|
||||||
return p
|
return p
|
||||||
|
dlls <- forM (catMaybes extrabins) findLibs
|
||||||
|
dllpaths <- mapM searchPath (nub (concat dlls))
|
||||||
webappscript <- vbsLauncher tmpdir "git-annex-webapp" "git-annex webapp"
|
webappscript <- vbsLauncher tmpdir "git-annex-webapp" "git-annex webapp"
|
||||||
autostartscript <- vbsLauncher tmpdir "git-annex-autostart" "git annex assistant --autostart"
|
autostartscript <- vbsLauncher tmpdir "git-annex-autostart" "git annex assistant --autostart"
|
||||||
let htmlhelp = tmpdir </> "git-annex.html"
|
let htmlhelp = tmpdir </> "git-annex.html"
|
||||||
writeFile htmlhelp htmlHelpText
|
writeFile htmlhelp htmlHelpText
|
||||||
writeFile nsifile $ makeInstaller gitannex license htmlhelp
|
writeFile nsifile $ makeInstaller gitannex license htmlhelp
|
||||||
(catMaybes extrabins)
|
(catMaybes (extrabins ++ dllpaths))
|
||||||
[ webappscript, autostartscript ]
|
[ webappscript, autostartscript ]
|
||||||
mustSucceed "makensis" [File nsifile]
|
mustSucceed "makensis" [File nsifile]
|
||||||
removeFile nsifile -- left behind if makensis fails
|
removeFile nsifile -- left behind if makensis fails
|
||||||
|
@ -169,54 +176,6 @@ makeInstaller gitannex license htmlhelp extrabins launchers = nsis $ do
|
||||||
cygwinPrograms :: [FilePath]
|
cygwinPrograms :: [FilePath]
|
||||||
cygwinPrograms = map (\p -> p ++ ".exe") bundledPrograms
|
cygwinPrograms = map (\p -> p ++ ".exe") bundledPrograms
|
||||||
|
|
||||||
-- These are the dlls needed by Cygwin's rsync, ssh, etc.
|
|
||||||
-- TODO: Use ldd (available in cygwin) to automatically find all
|
|
||||||
-- needed libs.
|
|
||||||
cygwinDlls :: [FilePath]
|
|
||||||
cygwinDlls =
|
|
||||||
[ "cygwin1.dll"
|
|
||||||
, "cygasn1-8.dll"
|
|
||||||
, "cygattr-1.dll"
|
|
||||||
, "cygheimbase-1.dll"
|
|
||||||
, "cygroken-18.dll"
|
|
||||||
, "cygcom_err-2.dll"
|
|
||||||
, "cygheimntlm-0.dll"
|
|
||||||
, "cygsqlite3-0.dll"
|
|
||||||
, "cygcrypt-0.dll"
|
|
||||||
, "cyghx509-5.dll"
|
|
||||||
, "cygssp-0.dll"
|
|
||||||
, "cygcrypto-1.0.0.dll"
|
|
||||||
, "cygiconv-2.dll"
|
|
||||||
, "cyggcc_s-1.dll"
|
|
||||||
, "cygintl-8.dll"
|
|
||||||
, "cygwind-0.dll"
|
|
||||||
, "cyggssapi-3.dll"
|
|
||||||
, "cyggssapi_krb5-2.dll"
|
|
||||||
, "cygkrb5-26.dll"
|
|
||||||
, "cygz.dll"
|
|
||||||
, "cygidn-11.dll"
|
|
||||||
, "cyggnutls-28.dll"
|
|
||||||
, "libcrypto.dll"
|
|
||||||
, "libssl.dll"
|
|
||||||
, "cyggcrypt-11.dll"
|
|
||||||
, "cyggpg-error-0.dll"
|
|
||||||
, "cygp11-kit-0.dll"
|
|
||||||
, "cygffi-6.dll"
|
|
||||||
, "cygbz2-1.dll"
|
|
||||||
, "cygreadline7.dll"
|
|
||||||
, "cygncursesw-10.dll"
|
|
||||||
, "cygusb0.dll"
|
|
||||||
, "cyghogweed-2.dll"
|
|
||||||
, "cygk5crypto-3.dll"
|
|
||||||
, "cygkrb5support-0.dll"
|
|
||||||
, "cyggmp-10.dll"
|
|
||||||
, "cygkrb5-3.dll"
|
|
||||||
, "cygnettle-4.dll"
|
|
||||||
, "cygtasn1-6.dll"
|
|
||||||
, "cygpcre-1.dll"
|
|
||||||
, "cyguuid-1.dll"
|
|
||||||
]
|
|
||||||
|
|
||||||
-- msysgit opens Program Files/Git/doc/git/html/git-annex.html
|
-- msysgit opens Program Files/Git/doc/git/html/git-annex.html
|
||||||
-- when git annex --help is run.
|
-- when git annex --help is run.
|
||||||
htmlHelpText :: String
|
htmlHelpText :: String
|
||||||
|
@ -229,3 +188,10 @@ htmlHelpText = unlines
|
||||||
, "</body>"
|
, "</body>"
|
||||||
, "</html"
|
, "</html"
|
||||||
]
|
]
|
||||||
|
|
||||||
|
findLibs :: FilePath -> IO [FilePath]
|
||||||
|
findLibs p = mapMaybe parse . lines <$> readProcess "ldd" [p]
|
||||||
|
where
|
||||||
|
parse l = case words (dropWhile isSpace l) of
|
||||||
|
(dll:"=>":_dllpath:_offset:[]) -> Just dll
|
||||||
|
_ -> Nothing
|
||||||
|
|
Loading…
Add table
Reference in a new issue