configure: hardcode some things that cannot be probed for when cross-compiling for Android
This commit is contained in:
parent
573e15b1df
commit
a7ef05a988
2 changed files with 25 additions and 6 deletions
|
@ -7,6 +7,7 @@ import Data.List
|
||||||
import System.Process
|
import System.Process
|
||||||
import Control.Applicative
|
import Control.Applicative
|
||||||
import System.FilePath
|
import System.FilePath
|
||||||
|
import System.Environment
|
||||||
|
|
||||||
import Build.TestConfig
|
import Build.TestConfig
|
||||||
import Utility.SafeCommand
|
import Utility.SafeCommand
|
||||||
|
@ -121,8 +122,26 @@ cleanup = removeDirectoryRecursive tmpDir
|
||||||
|
|
||||||
run :: [TestCase] -> IO ()
|
run :: [TestCase] -> IO ()
|
||||||
run ts = do
|
run ts = do
|
||||||
|
args <- getArgs
|
||||||
setup
|
setup
|
||||||
config <- runTests ts
|
config <- runTests ts
|
||||||
writeSysConfig config
|
if args == ["Android"]
|
||||||
|
then writeSysConfig $ androidConfig config
|
||||||
|
else writeSysConfig config
|
||||||
cleanup
|
cleanup
|
||||||
cabalSetup
|
cabalSetup
|
||||||
|
|
||||||
|
{- Hard codes some settings to cross-compile for Android. -}
|
||||||
|
androidConfig :: [Config] -> [Config]
|
||||||
|
androidConfig c = overrides ++ filter (not . overridden) c
|
||||||
|
where
|
||||||
|
overrides =
|
||||||
|
[ Config "cp_reflink_auto" $ BoolConfig False
|
||||||
|
, Config "curl" $ BoolConfig False
|
||||||
|
, Config "sshconnectioncaching" $ BoolConfig False
|
||||||
|
, Config "sha224" $ MaybeStringConfig Nothing
|
||||||
|
, Config "sha384" $ MaybeStringConfig Nothing
|
||||||
|
]
|
||||||
|
overridden (Config k _) = k `elem` overridekeys
|
||||||
|
overridekeys = map (\(Config k _) -> k) overrides
|
||||||
|
|
||||||
|
|
10
Makefile
10
Makefile
|
@ -13,8 +13,8 @@ mans=git-annex.1 git-annex-shell.1
|
||||||
sources=Build/SysConfig.hs Utility/Touch.hs Utility/Mounts.hs
|
sources=Build/SysConfig.hs Utility/Touch.hs Utility/Mounts.hs
|
||||||
all=$(bins) $(mans) docs
|
all=$(bins) $(mans) docs
|
||||||
|
|
||||||
OS:=$(shell uname | sed 's/[-_].*//')
|
OS?=$(shell uname | sed 's/[-_].*//')
|
||||||
ifeq ($(ANDROID),1)
|
ifeq ($(OS),Android)
|
||||||
OPTFLAGS?=-DWITH_INOTIFY -DWITH_ANDROID
|
OPTFLAGS?=-DWITH_INOTIFY -DWITH_ANDROID
|
||||||
clibs=Utility/libdiskfree.o Utility/libmounts.o
|
clibs=Utility/libdiskfree.o Utility/libmounts.o
|
||||||
CFLAGS:=-Wall -DWITH_ANDROID
|
CFLAGS:=-Wall -DWITH_ANDROID
|
||||||
|
@ -77,7 +77,7 @@ fast: $(bins)
|
||||||
|
|
||||||
Build/SysConfig.hs: configure.hs Build/TestConfig.hs Build/Configure.hs
|
Build/SysConfig.hs: configure.hs Build/TestConfig.hs Build/Configure.hs
|
||||||
$(GHCMAKE) configure
|
$(GHCMAKE) configure
|
||||||
./configure
|
./configure $(OS)
|
||||||
|
|
||||||
%.hs: %.hsc
|
%.hs: %.hsc
|
||||||
hsc2hs $<
|
hsc2hs $<
|
||||||
|
@ -231,11 +231,11 @@ osxapp:
|
||||||
# So the Android should have all the same stuff that configure probes for,
|
# So the Android should have all the same stuff that configure probes for,
|
||||||
# including the same version of git.
|
# including the same version of git.
|
||||||
android:
|
android:
|
||||||
$(MAKE) Build/SysConfig.hs
|
OS=Android $(MAKE) Build/SysConfig.hs
|
||||||
GHC=$$HOME/.ghc/android-14/arm-linux-androideabi-4.7/bin/arm-unknown-linux-androideabi-ghc \
|
GHC=$$HOME/.ghc/android-14/arm-linux-androideabi-4.7/bin/arm-unknown-linux-androideabi-ghc \
|
||||||
CC=$$HOME/.ghc/android-14/arm-linux-androideabi-4.7/bin/arm-linux-androideabi-gcc \
|
CC=$$HOME/.ghc/android-14/arm-linux-androideabi-4.7/bin/arm-linux-androideabi-gcc \
|
||||||
FEATURES="-DWITH_ANDROID -DWITH_ASSISTANT -DWITH_GLOB -DWITH_DNS" \
|
FEATURES="-DWITH_ANDROID -DWITH_ASSISTANT -DWITH_GLOB -DWITH_DNS" \
|
||||||
ANDROID=1 $(MAKE) fast
|
OS=Android $(MAKE) fast
|
||||||
|
|
||||||
# used by ./ghci
|
# used by ./ghci
|
||||||
getflags:
|
getflags:
|
||||||
|
|
Loading…
Reference in a new issue