summaryrefslogtreecommitdiff
path: root/standalone/android
diff options
context:
space:
mode:
authorGravatar Joey Hess <joey@kitenet.net>2013-12-16 23:05:00 -0400
committerGravatar Joey Hess <joey@kitenet.net>2013-12-16 23:05:00 -0400
commitbaec0fdf7e574290188ffc2d64a912bf9dd5fda2 (patch)
tree7536cf7266c5fff4f0590f83632b6e6b6969526a /standalone/android
parentc3ea7e50f0102008242ffeda974ed9eb9868c8d7 (diff)
begin work on installing TH-using dependencies of webapp, for standalone armel build
Will move common patches out of android/haskell-patches.
Diffstat (limited to 'standalone/android')
-rw-r--r--standalone/android/haskell-patches/DAV_build-without-TH.patch377
-rwxr-xr-xstandalone/android/install-haskell-packages14
2 files changed, 8 insertions, 383 deletions
diff --git a/standalone/android/haskell-patches/DAV_build-without-TH.patch b/standalone/android/haskell-patches/DAV_build-without-TH.patch
deleted file mode 100644
index b871fa9ef..000000000
--- a/standalone/android/haskell-patches/DAV_build-without-TH.patch
+++ /dev/null
@@ -1,377 +0,0 @@
-From 2b5fc33607720d0cccd7d8f9cb7232042ead73e6 Mon Sep 17 00:00:00 2001
-From: foo <foo@bar>
-Date: Sun, 22 Sep 2013 00:36:56 +0000
-Subject: [PATCH] expand TH
-
-used the EvilSplicer
-+ manual fix ups
----
- DAV.cabal | 20 +--
- Network/Protocol/HTTP/DAV.hs | 73 ++++++-----
- Network/Protocol/HTTP/DAV/TH.hs | 196 +++++++++++++++++++++++++++-
- dist/build/HSDAV-0.4.1.o | Bin 140080 -> 0 bytes
- dist/build/Network/Protocol/HTTP/DAV.hi | Bin 34549 -> 57657 bytes
- dist/build/Network/Protocol/HTTP/DAV.o | Bin 160248 -> 201932 bytes
- dist/build/Network/Protocol/HTTP/DAV/TH.hi | Bin 17056 -> 18733 bytes
- dist/build/Network/Protocol/HTTP/DAV/TH.o | Bin 19672 -> 28120 bytes
- dist/build/autogen/Paths_DAV.hs | 18 ++-
- dist/build/autogen/cabal_macros.h | 45 +++----
- dist/build/libHSDAV-0.4.1.a | Bin 200082 -> 260188 bytes
- dist/package.conf.inplace | 2 -
- dist/setup-config | 2 -
- 13 files changed, 266 insertions(+), 90 deletions(-)
- delete mode 100644 dist/build/HSDAV-0.4.1.o
- delete mode 100644 dist/package.conf.inplace
- delete mode 100644 dist/setup-config
-
-diff --git a/DAV.cabal b/DAV.cabal
-index 06b3a8b..90368c6 100644
---- a/DAV.cabal
-+++ b/DAV.cabal
-@@ -38,25 +38,7 @@ library
- , transformers >= 0.3
- , xml-conduit >= 1.0 && <= 1.2
- , xml-hamlet >= 0.4 && <= 0.5
--executable hdav
-- main-is: hdav.hs
-- ghc-options: -Wall
-- build-depends: base >= 4.5 && <= 5
-- , bytestring
-- , bytestring
-- , case-insensitive >= 0.4
-- , containers
-- , http-conduit >= 1.9.0
-- , http-types >= 0.7
-- , lens >= 3.0
-- , lifted-base >= 0.1
-- , mtl >= 2.1
-- , network >= 2.3
-- , optparse-applicative
-- , resourcet >= 0.3
-- , transformers >= 0.3
-- , xml-conduit >= 1.0 && <= 1.2
-- , xml-hamlet >= 0.4 && <= 0.5
-+ , text
-
- source-repository head
- type: git
-diff --git a/Network/Protocol/HTTP/DAV.hs b/Network/Protocol/HTTP/DAV.hs
-index 8ffc270..d064a8f 100644
---- a/Network/Protocol/HTTP/DAV.hs
-+++ b/Network/Protocol/HTTP/DAV.hs
-@@ -28,12 +28,12 @@ module Network.Protocol.HTTP.DAV (
- , deleteContent
- , moveContent
- , makeCollection
-- , caldavReport
- , module Network.Protocol.HTTP.DAV.TH
- ) where
-
- import Network.Protocol.HTTP.DAV.TH
-
-+import qualified Data.Text
- import Control.Applicative (liftA2)
- import Control.Exception.Lifted (catchJust, finally, bracketOnError)
- import Control.Lens ((.~), (^.))
-@@ -200,11 +200,6 @@ props2patch = XML.renderLBS XML.def . patch . props . fromDocument
- , "{DAV:}supportedlock"
- ]
-
--caldavReportM :: MonadResourceBase m => DAVState m XML.Document
--caldavReportM = do
-- let ahs = [(hContentType, "application/xml; charset=\"utf-8\"")]
-- calrresp <- davRequest "REPORT" ahs (xmlBody calendarquery)
-- return $ (XML.parseLBS_ def . responseBody) calrresp
-
- getProps :: String -> B.ByteString -> B.ByteString -> Maybe Depth -> IO XML.Document
- getProps url username password md = withDS url username password md getPropsM
-@@ -246,9 +241,6 @@ moveContent :: String -> B.ByteString -> B.ByteString -> B.ByteString -> IO ()
- moveContent url newurl username password = withDS url username password Nothing $
- moveContentM newurl
-
--caldavReport :: String -> B.ByteString -> B.ByteString -> IO XML.Document
--caldavReport url username password = withDS url username password (Just Depth1) $ caldavReportM
--
- -- | Creates a WebDAV collection, which is similar to a directory.
- --
- -- Returns False if the collection could not be made due to an intermediate
-@@ -264,28 +256,45 @@ makeCollection url username password = withDS url username password Nothing $
- propname :: XML.Document
- propname = XML.Document (XML.Prologue [] Nothing []) root []
- where
-- root = XML.Element "D:propfind" (Map.fromList [("xmlns:D", "DAV:")]) [xml|
--<D:allprop>
--|]
--
-+ root = XML.Element "D:propfind" (Map.fromList [("xmlns:D", "DAV:")]) $ concat
-+ [[XML.NodeElement
-+ (XML.Element
-+ (XML.Name
-+ (Data.Text.pack "D:allprop") Nothing Nothing)
-+ Map.empty
-+ (concat []))]]
- locky :: XML.Document
- locky = XML.Document (XML.Prologue [] Nothing []) root []
-- where
-- root = XML.Element "D:lockinfo" (Map.fromList [("xmlns:D", "DAV:")]) [xml|
--<D:lockscope>
-- <D:exclusive>
--<D:locktype>
-- <D:write>
--<D:owner>Haskell DAV user
--|]
--
--calendarquery :: XML.Document
--calendarquery = XML.Document (XML.Prologue [] Nothing []) root []
-- where
-- root = XML.Element "C:calendar-query" (Map.fromList [("xmlns:D", "DAV:"),("xmlns:C", "urn:ietf:params:xml:ns:caldav")]) [xml|
--<D:prop>
-- <D:getetag>
-- <C:calendar-data>
--<C:filter>
-- <C:comp-filter name="VCALENDAR">
--|]
-+ where
-+ root = XML.Element "D:lockinfo" (Map.fromList [("xmlns:D", "DAV:")]) $ concat
-+ [[XML.NodeElement
-+ (XML.Element
-+ (XML.Name
-+ (Data.Text.pack "D:lockscope") Nothing Nothing)
-+ Map.empty
-+ (concat
-+ [[XML.NodeElement
-+ (XML.Element
-+ (XML.Name
-+ (Data.Text.pack "D:exclusive") Nothing Nothing)
-+ Map.empty
-+ (concat []))]]))],
-+ [XML.NodeElement
-+ (XML.Element
-+ (XML.Name
-+ (Data.Text.pack "D:locktype") Nothing Nothing)
-+ Map.empty
-+ (concat
-+ [[XML.NodeElement
-+ (XML.Element
-+ (XML.Name (Data.Text.pack "D:write") Nothing Nothing)
-+ Map.empty
-+ (concat []))]]))],
-+ [XML.NodeElement
-+ (XML.Element
-+ (XML.Name (Data.Text.pack "D:owner") Nothing Nothing)
-+ Map.empty
-+ (concat
-+ [[XML.NodeContent
-+ (Data.Text.pack "Haskell DAV user")]]))]]
-+
-diff --git a/Network/Protocol/HTTP/DAV/TH.hs b/Network/Protocol/HTTP/DAV/TH.hs
-index 9fb3495..18b8df7 100644
---- a/Network/Protocol/HTTP/DAV/TH.hs
-+++ b/Network/Protocol/HTTP/DAV/TH.hs
-@@ -20,7 +20,8 @@
-
- module Network.Protocol.HTTP.DAV.TH where
-
--import Control.Lens (makeLenses)
-+import qualified Control.Lens.Type
-+import qualified Data.Functor
- import qualified Data.ByteString as B
- import Network.HTTP.Conduit (Manager, Request)
-
-@@ -46,4 +47,195 @@ data DAVContext a = DAVContext {
- , _basicpassword :: B.ByteString
- , _depth :: Maybe Depth
- }
--makeLenses ''DAVContext
-+allowedMethods ::
-+ Control.Lens.Type.Lens' (DAVContext a_a4I4) [B.ByteString]
-+allowedMethods
-+ _f_a5GM
-+ (DAVContext __allowedMethods'_a5GN
-+ __baseRequest_a5GP
-+ __complianceClasses_a5GQ
-+ __httpManager_a5GR
-+ __lockToken_a5GS
-+ __basicusername_a5GT
-+ __basicpassword_a5GU
-+ __depth_a5GV)
-+ = ((\ __allowedMethods_a5GO
-+ -> DAVContext
-+ __allowedMethods_a5GO
-+ __baseRequest_a5GP
-+ __complianceClasses_a5GQ
-+ __httpManager_a5GR
-+ __lockToken_a5GS
-+ __basicusername_a5GT
-+ __basicpassword_a5GU
-+ __depth_a5GV)
-+ Data.Functor.<$> (_f_a5GM __allowedMethods'_a5GN))
-+{-# INLINE allowedMethods #-}
-+baseRequest ::
-+ Control.Lens.Type.Lens (DAVContext a_a4I4) (DAVContext a_a5GW) (Request a_a4I4) (Request a_a5GW)
-+baseRequest
-+ _f_a5GX
-+ (DAVContext __allowedMethods_a5GY
-+ __baseRequest'_a5GZ
-+ __complianceClasses_a5H1
-+ __httpManager_a5H2
-+ __lockToken_a5H3
-+ __basicusername_a5H4
-+ __basicpassword_a5H5
-+ __depth_a5H6)
-+ = ((\ __baseRequest_a5H0
-+ -> DAVContext
-+ __allowedMethods_a5GY
-+ __baseRequest_a5H0
-+ __complianceClasses_a5H1
-+ __httpManager_a5H2
-+ __lockToken_a5H3
-+ __basicusername_a5H4
-+ __basicpassword_a5H5
-+ __depth_a5H6)
-+ Data.Functor.<$> (_f_a5GX __baseRequest'_a5GZ))
-+{-# INLINE baseRequest #-}
-+basicpassword ::
-+ Control.Lens.Type.Lens' (DAVContext a_a4I4) B.ByteString
-+basicpassword
-+ _f_a5H7
-+ (DAVContext __allowedMethods_a5H8
-+ __baseRequest_a5H9
-+ __complianceClasses_a5Ha
-+ __httpManager_a5Hb
-+ __lockToken_a5Hc
-+ __basicusername_a5Hd
-+ __basicpassword'_a5He
-+ __depth_a5Hg)
-+ = ((\ __basicpassword_a5Hf
-+ -> DAVContext
-+ __allowedMethods_a5H8
-+ __baseRequest_a5H9
-+ __complianceClasses_a5Ha
-+ __httpManager_a5Hb
-+ __lockToken_a5Hc
-+ __basicusername_a5Hd
-+ __basicpassword_a5Hf
-+ __depth_a5Hg)
-+ Data.Functor.<$> (_f_a5H7 __basicpassword'_a5He))
-+{-# INLINE basicpassword #-}
-+basicusername ::
-+ Control.Lens.Type.Lens' (DAVContext a_a4I4) B.ByteString
-+basicusername
-+ _f_a5Hh
-+ (DAVContext __allowedMethods_a5Hi
-+ __baseRequest_a5Hj
-+ __complianceClasses_a5Hk
-+ __httpManager_a5Hl
-+ __lockToken_a5Hm
-+ __basicusername'_a5Hn
-+ __basicpassword_a5Hp
-+ __depth_a5Hq)
-+ = ((\ __basicusername_a5Ho
-+ -> DAVContext
-+ __allowedMethods_a5Hi
-+ __baseRequest_a5Hj
-+ __complianceClasses_a5Hk
-+ __httpManager_a5Hl
-+ __lockToken_a5Hm
-+ __basicusername_a5Ho
-+ __basicpassword_a5Hp
-+ __depth_a5Hq)
-+ Data.Functor.<$> (_f_a5Hh __basicusername'_a5Hn))
-+{-# INLINE basicusername #-}
-+complianceClasses ::
-+ Control.Lens.Type.Lens' (DAVContext a_a4I4) [B.ByteString]
-+complianceClasses
-+ _f_a5Hr
-+ (DAVContext __allowedMethods_a5Hs
-+ __baseRequest_a5Ht
-+ __complianceClasses'_a5Hu
-+ __httpManager_a5Hw
-+ __lockToken_a5Hx
-+ __basicusername_a5Hy
-+ __basicpassword_a5Hz
-+ __depth_a5HA)
-+ = ((\ __complianceClasses_a5Hv
-+ -> DAVContext
-+ __allowedMethods_a5Hs
-+ __baseRequest_a5Ht
-+ __complianceClasses_a5Hv
-+ __httpManager_a5Hw
-+ __lockToken_a5Hx
-+ __basicusername_a5Hy
-+ __basicpassword_a5Hz
-+ __depth_a5HA)
-+ Data.Functor.<$> (_f_a5Hr __complianceClasses'_a5Hu))
-+{-# INLINE complianceClasses #-}
-+depth ::
-+ Control.Lens.Type.Lens' (DAVContext a_a4I4) (Maybe Depth)
-+depth
-+ _f_a5HB
-+ (DAVContext __allowedMethods_a5HC
-+ __baseRequest_a5HD
-+ __complianceClasses_a5HE
-+ __httpManager_a5HF
-+ __lockToken_a5HG
-+ __basicusername_a5HH
-+ __basicpassword_a5HI
-+ __depth'_a5HJ)
-+ = ((\ __depth_a5HK
-+ -> DAVContext
-+ __allowedMethods_a5HC
-+ __baseRequest_a5HD
-+ __complianceClasses_a5HE
-+ __httpManager_a5HF
-+ __lockToken_a5HG
-+ __basicusername_a5HH
-+ __basicpassword_a5HI
-+ __depth_a5HK)
-+ Data.Functor.<$> (_f_a5HB __depth'_a5HJ))
-+{-# INLINE depth #-}
-+httpManager ::
-+ Control.Lens.Type.Lens' (DAVContext a_a4I4) Manager
-+httpManager
-+ _f_a5HL
-+ (DAVContext __allowedMethods_a5HM
-+ __baseRequest_a5HN
-+ __complianceClasses_a5HO
-+ __httpManager'_a5HP
-+ __lockToken_a5HR
-+ __basicusername_a5HS
-+ __basicpassword_a5HT
-+ __depth_a5HU)
-+ = ((\ __httpManager_a5HQ
-+ -> DAVContext
-+ __allowedMethods_a5HM
-+ __baseRequest_a5HN
-+ __complianceClasses_a5HO
-+ __httpManager_a5HQ
-+ __lockToken_a5HR
-+ __basicusername_a5HS
-+ __basicpassword_a5HT
-+ __depth_a5HU)
-+ Data.Functor.<$> (_f_a5HL __httpManager'_a5HP))
-+{-# INLINE httpManager #-}
-+lockToken ::
-+ Control.Lens.Type.Lens' (DAVContext a_a4I4) (Maybe B.ByteString)
-+lockToken
-+ _f_a5HV
-+ (DAVContext __allowedMethods_a5HW
-+ __baseRequest_a5HX
-+ __complianceClasses_a5HY
-+ __httpManager_a5HZ
-+ __lockToken'_a5I0
-+ __basicusername_a5I2
-+ __basicpassword_a5I3
-+ __depth_a5I4)
-+ = ((\ __lockToken_a5I1
-+ -> DAVContext
-+ __allowedMethods_a5HW
-+ __baseRequest_a5HX
-+ __complianceClasses_a5HY
-+ __httpManager_a5HZ
-+ __lockToken_a5I1
-+ __basicusername_a5I2
-+ __basicpassword_a5I3
-+ __depth_a5I4)
-+ Data.Functor.<$> (_f_a5HV __lockToken'_a5I0))
-+{-# INLINE lockToken #-}
diff --git a/standalone/android/install-haskell-packages b/standalone/android/install-haskell-packages
index a8d4a18f9..b78eda83a 100755
--- a/standalone/android/install-haskell-packages
+++ b/standalone/android/install-haskell-packages
@@ -35,12 +35,14 @@ patched () {
git config user.email dummy@example.com
git add .
git commit -m "pre-patched state of $pkg"
- for patch in ../../haskell-patches/${pkg}_*; do
- echo trying $patch
- if ! patch -p1 < $patch; then
- echo "failed to apply $patch"
- echo "please resolve this, replace the patch with a new version, and exit the subshell to continue"
- $SHELL
+ for patch in ../../haskell-patches/${pkg}_* ../../../haskell-patches/no-th/${pkg}_*; do
+ if [ -e "$patch" ]; then
+ echo trying $patch
+ if ! patch -p1 < $patch; then
+ echo "failed to apply $patch"
+ echo "please resolve this, replace the patch with a new version, and exit the subshell to continue"
+ $SHELL
+ fi
fi
done
cabalinstall "$@"