aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--standalone/android/cabal.config3
-rw-r--r--standalone/android/haskell-patches/clock_hack-for-android.patch76
-rwxr-xr-xstandalone/android/install-haskell-packages1
3 files changed, 79 insertions, 1 deletions
diff --git a/standalone/android/cabal.config b/standalone/android/cabal.config
index de7d72dc0..4cda02637 100644
--- a/standalone/android/cabal.config
+++ b/standalone/android/cabal.config
@@ -204,4 +204,5 @@ constraints: Crypto ==4.2.5.1,
yesod-static ==1.2.4,
zlib ==0.5.4.1,
bytestring ==0.10.4.0,
- scientific ==0.3.3.1
+ scientific ==0.3.3.1,
+ clock ==0.4.6.0
diff --git a/standalone/android/haskell-patches/clock_hack-for-android.patch b/standalone/android/haskell-patches/clock_hack-for-android.patch
new file mode 100644
index 000000000..d2c39ff53
--- /dev/null
+++ b/standalone/android/haskell-patches/clock_hack-for-android.patch
@@ -0,0 +1,76 @@
+From 5be3bdfc5ec83eaa5defd42e99f73a685123bea0 Mon Sep 17 00:00:00 2001
+From: androidbuilder <androidbuilder@example.com>
+Date: Fri, 22 May 2015 18:35:43 +0000
+Subject: [PATCH] hack for android
+
+---
+ System/Clock.hsc | 32 ++------------------------------
+ 1 file changed, 2 insertions(+), 30 deletions(-)
+
+diff --git a/System/Clock.hsc b/System/Clock.hsc
+index b6a4968..92bcf8b 100644
+--- a/System/Clock.hsc
++++ b/System/Clock.hsc
+@@ -35,8 +35,6 @@ import GHC.Generics (Generic)
+ # endif
+ #endif
+
+-#let alignment t = "%lu", (unsigned long)offsetof(struct {char x__; t (y__); }, y__)
+-
+ -- | Clock types. A clock may be system-wide (that is, visible to all processes)
+ -- or per-process (measuring time that is meaningful only within a process).
+ -- All implementations shall support CLOCK_REALTIME.
+@@ -119,7 +117,7 @@ getTime ThreadCPUTime = allocaAndPeek hs_clock_win32_gettime_threadtime
+ #elif defined(__MACH__)
+ getTime clk = allocaAndPeek $ hs_clock_darwin_gettime $ clockToConst clk
+ #else
+-getTime clk = allocaAndPeek $ clock_gettime $ clockToConst clk
++getTime clk = error "getTime clk not implemented"
+ #endif
+
+ #if defined(_WIN32)
+@@ -130,7 +128,7 @@ getRes ThreadCPUTime = allocaAndPeek hs_clock_win32_getres_threadtime
+ #elif defined(__MACH__)
+ getRes clk = allocaAndPeek $ hs_clock_darwin_getres $ clockToConst clk
+ #else
+-getRes clk = allocaAndPeek $ clock_getres $ clockToConst clk
++getRes clk = error "getRes clk not implemented"
+ #endif
+
+ -- | TimeSpec structure
+@@ -139,32 +137,6 @@ data TimeSpec = TimeSpec
+ , nsec :: {-# UNPACK #-} !Int64 -- ^ nanoseconds
+ } deriving (Eq, Generic, Read, Show, Typeable)
+
+-#if defined(_WIN32)
+-instance Storable TimeSpec where
+- sizeOf _ = sizeOf (undefined :: Int64) * 2
+- alignment _ = alignment (undefined :: Int64)
+- poke ptr ts = do
+- pokeByteOff ptr 0 (sec ts)
+- pokeByteOff ptr (sizeOf (undefined :: Int64)) (nsec ts)
+- peek ptr = do
+- TimeSpec
+- <$> peekByteOff ptr 0
+- <*> peekByteOff ptr (sizeOf (undefined :: Int64))
+-#else
+-instance Storable TimeSpec where
+- sizeOf _ = #{size struct timespec}
+- alignment _ = #{alignment struct timespec}
+- poke ptr ts = do
+- let xs :: #{type time_t} = fromIntegral $ sec ts
+- xn :: #{type long} = fromIntegral $ nsec ts
+- #{poke struct timespec, tv_sec} ptr (xs)
+- #{poke struct timespec, tv_nsec} ptr (xn)
+- peek ptr = do
+- xs :: #{type time_t} <- #{peek struct timespec, tv_sec} ptr
+- xn :: #{type long} <- #{peek struct timespec, tv_nsec} ptr
+- return $ TimeSpec (fromIntegral xs) (fromIntegral xn)
+-#endif
+-
+ normalize :: TimeSpec -> TimeSpec
+ normalize (TimeSpec xs xn) =
+ let (q, r) = xn `divMod` (10^9)
+--
+2.1.4
+
diff --git a/standalone/android/install-haskell-packages b/standalone/android/install-haskell-packages
index fcc31c71c..c834883bb 100755
--- a/standalone/android/install-haskell-packages
+++ b/standalone/android/install-haskell-packages
@@ -112,6 +112,7 @@ EOF
patched yesod-persistent
patched yesod-form
patched crypto-numbers
+ patched clock
patched yesod-auth
patched yesod
patched shakespeare-text