{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE QuasiQuotes #-}
{-# LANGUAGE RecordWildCards #-}
module Distribution.ArchHs.PkgBuild
( PkgBuild (..),
mapLicense,
showArchLicense,
applyTemplate,
felixTemplate,
)
where
import qualified Data.Aeson as A
import Data.Text (Text, pack, unpack)
import qualified Data.Text as T
import Distribution.SPDX.LicenseId
import NeatInterpolation (text)
import qualified Web.ArchLinux.Types as Arch
data PkgBuild = PkgBuild
{
PkgBuild -> String
_hkgName :: String,
PkgBuild -> String
_pkgName :: String,
PkgBuild -> String
_pkgVer :: String,
PkgBuild -> String
_pkgDesc :: String,
PkgBuild -> String
_url :: String,
PkgBuild -> String
_license :: String,
PkgBuild -> String
_depends :: String,
PkgBuild -> String
_makeDepends :: String,
PkgBuild -> String
_sha256sums :: String,
PkgBuild -> Maybe String
_licenseFile :: Maybe String,
PkgBuild -> Bool
_enableUusi :: Bool,
PkgBuild -> Bool
_enableCheck :: Bool
}
mapLicense :: LicenseId -> Arch.License
mapLicense :: LicenseId -> License
mapLicense LicenseId
AGPL_3_0_only = License
Arch.AGPL3
mapLicense LicenseId
Apache_2_0 = License
Arch.Apache
mapLicense LicenseId
Artistic_2_0 = License
Arch.Artistic2_0
mapLicense LicenseId
CDDL_1_0 = License
Arch.CDDL
mapLicense LicenseId
CPL_1_0 = License
Arch.CPL
mapLicense LicenseId
EPL_1_0 = License
Arch.EPL
mapLicense LicenseId
GFDL_1_2_only = License
Arch.FDL1_2
mapLicense LicenseId
GFDL_1_3_only = License
Arch.FDL1_3
mapLicense LicenseId
GPL_2_0_only = License
Arch.GPL2
mapLicense LicenseId
GPL_3_0_only = License
Arch.GPL3
mapLicense LicenseId
LGPL_2_1_only = License
Arch.LGPL2_1
mapLicense LicenseId
LGPL_3_0_only = License
Arch.LGPL3
mapLicense LicenseId
LPPL_1_3c = License
Arch.LPPL
mapLicense LicenseId
MPL_1_0 = License
Arch.MPL
mapLicense LicenseId
MPL_2_0 = License
Arch.MPL2
mapLicense LicenseId
PHP_3_01 = License
Arch.PHP
mapLicense LicenseId
Python_2_0 = License
Arch.PSF
mapLicense LicenseId
Artistic_1_0_Perl = License
Arch.PerlArtistic
mapLicense LicenseId
Ruby = License
Arch.RUBY
mapLicense LicenseId
ZPL_2_1 = License
Arch.ZPL
mapLicense LicenseId
Unlicense = License
Arch.Unlicense
mapLicense LicenseId
W3C = License
Arch.W3C
mapLicense LicenseId
BSD_3_Clause = Text -> License
Arch.Custom Text
"BSD3"
mapLicense LicenseId
x = Text -> License
Arch.Custom (Text -> License) -> (String -> Text) -> String -> License
forall b c a. (b -> c) -> (a -> b) -> a -> c
. String -> Text
T.pack (String -> License) -> String -> License
forall a b. (a -> b) -> a -> b
$ LicenseId -> String
forall a. Show a => a -> String
show LicenseId
x
showArchLicense :: Arch.License -> String
showArchLicense :: License -> String
showArchLicense License
license = case License -> Value
forall a. ToJSON a => a -> Value
A.toJSON License
license of
(A.String Text
x) -> Text -> String
T.unpack Text
x
Value
_ -> String -> String
forall a. HasCallStack => String -> a
error String
"impossible"
applyTemplate :: PkgBuild -> String
applyTemplate :: PkgBuild -> String
applyTemplate PkgBuild {Bool
String
Maybe String
_enableCheck :: Bool
_enableUusi :: Bool
_licenseFile :: Maybe String
_sha256sums :: String
_makeDepends :: String
_depends :: String
_license :: String
_url :: String
_pkgDesc :: String
_pkgVer :: String
_pkgName :: String
_hkgName :: String
_enableCheck :: PkgBuild -> Bool
_enableUusi :: PkgBuild -> Bool
_licenseFile :: PkgBuild -> Maybe String
_sha256sums :: PkgBuild -> String
_makeDepends :: PkgBuild -> String
_depends :: PkgBuild -> String
_license :: PkgBuild -> String
_url :: PkgBuild -> String
_pkgDesc :: PkgBuild -> String
_pkgVer :: PkgBuild -> String
_pkgName :: PkgBuild -> String
_hkgName :: PkgBuild -> String
..} =
Text -> String
unpack (Text -> String) -> Text -> String
forall a b. (a -> b) -> a -> b
$
Text
-> Text
-> Text
-> Text
-> Text
-> Text
-> Text
-> Text
-> Text
-> Text
-> Text
-> Text
-> Text
felixTemplate
(String -> Text
pack String
_hkgName)
(String -> Text
pack String
_pkgName)
(String -> Text
pack String
_pkgVer)
(String -> Text
pack String
_pkgDesc)
(String -> Text
pack String
_url)
(String -> Text
pack String
_license)
(String -> Text
pack String
_depends)
(String -> Text
pack String
_makeDepends)
(String -> Text
pack String
_sha256sums)
( case Maybe String
_licenseFile of
Just String
n -> Text
"\n" Text -> Text -> Text
forall a. Semigroup a => a -> a -> a
<> Text -> Text
installLicense (String -> Text
pack String
n)
Maybe String
_ -> Text
"\n"
)
(if Bool
_enableUusi then Text
"\n" Text -> Text -> Text
forall a. Semigroup a => a -> a -> a
<> Text
uusi Text -> Text -> Text
forall a. Semigroup a => a -> a -> a
<> Text
"\n\n" else Text
"\n")
(if Bool
_enableCheck then Text
"\n" Text -> Text -> Text
forall a. Semigroup a => a -> a -> a
<> Text
check Text -> Text -> Text
forall a. Semigroup a => a -> a -> a
<> Text
"\n\n" else Text
"\n")
check :: Text
check :: Text
check =
[text|
check() {
cd $$_hkgname-$$pkgver
runhaskell Setup test
}
|]
installLicense :: Text -> Text
installLicense :: Text -> Text
installLicense Text
licenseFile =
[text|
install -D -m644 $licenseFile -t "$$pkgdir"/usr/share/licenses/$$pkgname/
rm -f "$$pkgdir"/usr/share/doc/$$pkgname/$licenseFile
|]
uusi :: Text
uusi :: Text
uusi =
[text|
prepare() {
uusi $$_hkgname-$$pkgver/$$_hkgname.cabal
}
|]
felixTemplate :: Text -> Text -> Text -> Text -> Text -> Text -> Text -> Text -> Text -> Text -> Text -> Text -> Text
felixTemplate :: Text
-> Text
-> Text
-> Text
-> Text
-> Text
-> Text
-> Text
-> Text
-> Text
-> Text
-> Text
-> Text
felixTemplate Text
hkgname Text
pkgname Text
pkgver Text
pkgdesc Text
url Text
license Text
depends Text
makedepends Text
sha256sums Text
licenseF Text
uusiF Text
checkF =
[text|
# This file was generated by https://github.com/berberman/arch-hs, please check it manually.
# Maintainer: Your Name <youremail@domain.com>
_hkgname=$hkgname
pkgname=$pkgname
pkgver=$pkgver
pkgrel=1
pkgdesc="$pkgdesc"
url="$url"
license=("$license")
arch=('x86_64')
depends=('ghc-libs'$depends)
makedepends=('ghc'$makedepends)
source=("https://hackage.haskell.org/packages/archive/$$_hkgname/$$pkgver/$$_hkgname-$$pkgver.tar.gz")
sha256sums=($sha256sums)
$uusiF
build() {
cd $$_hkgname-$$pkgver
runhaskell Setup configure -O --enable-shared --enable-executable-dynamic --disable-library-vanilla \
--prefix=/usr --docdir=/usr/share/doc/$$pkgname --enable-tests \
--dynlibdir=/usr/lib --libsubdir=\$$compiler/site-local/\$$pkgid \
--ghc-option=-optl-Wl\,-z\,relro\,-z\,now \
--ghc-option='-pie'
runhaskell Setup build
runhaskell Setup register --gen-script
runhaskell Setup unregister --gen-script
sed -i -r -e "s|ghc-pkg.*update[^ ]* |&'--force' |" register.sh
sed -i -r -e "s|ghc-pkg.*unregister[^ ]* |&'--force' |" unregister.sh
}
$checkF
package() {
cd $$_hkgname-$$pkgver
install -D -m744 register.sh "$$pkgdir"/usr/share/haskell/register/$$pkgname.sh
install -D -m744 unregister.sh "$$pkgdir"/usr/share/haskell/unregister/$$pkgname.sh
runhaskell Setup copy --destdir="$$pkgdir"$licenseF
}
|]