[arch-commits] Commit in ghc/repos (7 files)

Felix Yan felixonmars at archlinux.org
Mon Jul 3 09:28:49 UTC 2017


    Date: Monday, July 3, 2017 @ 09:28:48
  Author: felixonmars
Revision: 242139

archrelease: copy trunk to community-testing-x86_64

Added:
  ghc/repos/community-testing-x86_64/
  ghc/repos/community-testing-x86_64/PKGBUILD
    (from rev 242136, ghc/trunk/PKGBUILD)
  ghc/repos/community-testing-x86_64/ghc-rebuild-doc-index.hook
    (from rev 242136, ghc/trunk/ghc-rebuild-doc-index.hook)
  ghc/repos/community-testing-x86_64/ghc-register.hook
    (from rev 242136, ghc/trunk/ghc-register.hook)
  ghc/repos/community-testing-x86_64/ghc-unregister.hook
    (from rev 242137, ghc/trunk/ghc-unregister.hook)
  ghc/repos/community-testing-x86_64/ghc.install
    (from rev 242138, ghc/trunk/ghc.install)
  ghc/repos/community-testing-x86_64/print-provides-replaces.sh
    (from rev 242138, ghc/trunk/print-provides-replaces.sh)

----------------------------+
 PKGBUILD                   |  143 +++++++++++++++++++++++++++++++++++++++++++
 ghc-rebuild-doc-index.hook |   14 ++++
 ghc-register.hook          |   12 +++
 ghc-unregister.hook        |   12 +++
 ghc.install                |   10 +++
 print-provides-replaces.sh |   45 +++++++++++++
 6 files changed, 236 insertions(+)

Copied: ghc/repos/community-testing-x86_64/PKGBUILD (from rev 242136, ghc/trunk/PKGBUILD)
===================================================================
--- community-testing-x86_64/PKGBUILD	                        (rev 0)
+++ community-testing-x86_64/PKGBUILD	2017-07-03 09:28:48 UTC (rev 242139)
@@ -0,0 +1,143 @@
+# $Id$
+# Maintainer: Felix Yan <felixonmars at archlinux.org>
+# Contributor: Vesa Kaihlavirta <vesa at archlinux.org>
+# Contributor: Thomas Dziedzic <gostrc at gmail.com>
+
+# Special note for devs looking to upgrade this package:
+#   ghc places a unique hash for each library when it is built.
+#   Libraries depend on versions specified by those hashes.
+#   This implies that all libraries need to be rebuilt when ghc is rebuilt.
+
+# use the following command to print out packages that need to get rebuilt
+# grep -r ghc /var/abs/ | awk -F '/' '{ print $5; }' | sort -u
+
+pkgbase=ghc
+pkgname=(ghc ghc-static)
+pkgver=8.0.2
+pkgrel=2
+pkgdesc='The Glasgow Haskell Compiler'
+arch=('i686' 'x86_64')
+url='http://www.haskell.org/ghc/'
+license=('custom')
+makedepends=('ghc-static' 'perl' 'libxslt' 'docbook-xsl' 'python-sphinx' 'haskell-hscolour'
+             'texlive-bin' 'texlive-latexextra' 'ttf-dejavu')
+source=("https://downloads.haskell.org/~ghc/$pkgver/$pkgname-${pkgver}-src.tar.xz"
+        ghc-rebuild-doc-index.hook ghc-register.hook ghc-unregister.hook)
+noextract=("$pkgname-${pkgver}-src.tar.xz")
+md5sums=('d0afb5ec441b14527a53d2445cc26ec3'
+         'cc9aa11fddde15d8e5e15e99748874a1'
+         '3b1949e77038b0276ebd5590ab89e1af'
+         '587efb0cb73a6b336cd9333fc5697de4')
+
+prepare() {
+  # Need to extract this tarball with a UTF-8 locale instead of a chroot's "C"
+  # locale; otherwise we get:
+  #   bsdtar: Pathname can't be converted from UTF-8 to current locale.
+  LANG=en_US.UTF-8 bsdtar xf $pkgname-${pkgver}-src.tar.xz
+
+  cd ghc-$pkgver
+
+  cp mk/build.mk{.sample,}
+  sed -i '1iBuildFlavour = perf' mk/build.mk
+}
+
+build() {
+  cd ghc-$pkgver
+
+  ./configure \
+    --prefix=/usr \
+    --docdir=/usr/share/doc/ghc \
+    --with-system-libffi \
+    --with-ffi-includes=$(pkg-config --variable=includedir libffi)
+  make
+}
+
+package_ghc-static() {
+  pkgdesc='The Glasgow Haskell Compiler - Static Libraries'
+  depends=('ghc')
+
+  cd ghc-$pkgver
+
+  make DESTDIR="$pkgdir" -j1 install
+
+  mv "$pkgdir"/usr/lib/ghc-$pkgver/package.conf.d "$srcdir"/static-package.conf.d
+  find "$pkgdir"/usr/lib ! \( -name "*.a" -o -name "*.p_hi" \) -type f -delete
+  find "$pkgdir"/usr/lib -type d -empty -delete
+  mv "$srcdir"/static-package.conf.d "$pkgdir"/usr/lib/ghc-$pkgver/
+  rm -r "$pkgdir"/usr/share "$pkgdir"/usr/bin
+}
+
+package_ghc() {
+  pkgdesc='The Glasgow Haskell Compiler'
+  install='ghc.install'
+  depends=('gcc' 'gmp' 'libffi' 'perl')
+  provides=('haskell-array=0.5.1.1'
+            'haskell-base=4.9.1.0'
+            'haskell-binary=0.8.3.0'
+            'haskell-bytestring=0.10.8.1'
+            'haskell-containers=0.5.7.1'
+            'haskell-deepseq=1.4.2.0'
+            'haskell-directory=1.3.0.0'
+            'haskell-filepath=1.4.1.1'
+            'haskell-ghc-boot=8.0.2'
+            'haskell-ghc-boot-th=8.0.2'
+            'haskell-ghc-prim=0.5.0.0'
+            'haskell-haskeline=0.7.3.0'
+            'haskell-hoopl=3.10.2.1'
+            'haskell-hpc=0.6.0.3'
+            'haskell-integer-gmp=1.0.0.1'
+            'haskell-pretty=1.1.3.3'
+            'haskell-process=1.4.3.0'
+            'haskell-template-haskell=2.11.1.0'
+            'haskell-terminfo=0.4.0.2'
+            'haskell-time=1.6.0.1'
+            'haskell-transformers=0.5.2.0'
+            'haskell-unix=2.7.2.1'
+            'haskell-xhtml=3000.2.1'
+            'haskell-cabal=1.24.2.0')
+  replaces=('haskell-array'
+            'haskell-base'
+            'haskell-binary'
+            'haskell-bytestring'
+            'haskell-containers'
+            'haskell-deepseq'
+            'haskell-directory'
+            'haskell-filepath'
+            'haskell-ghc-boot'
+            'haskell-ghc-boot-th'
+            'haskell-ghc-prim'
+            'haskell-haskeline'
+            'haskell-hoopl'
+            'haskell-hpc'
+            'haskell-integer-gmp'
+            'haskell-pretty'
+            'haskell-process'
+            'haskell-template-haskell'
+            'haskell-terminfo'
+            'haskell-time'
+            'haskell-transformers'
+            'haskell-unix'
+            'haskell-xhtml'
+            'haskell-cabal')
+  provides+=("haskell-ghc=$pkgver")
+  replaces+=("haskell-ghc")
+
+  cd ghc-$pkgver
+
+  make DESTDIR="$pkgdir" -j1 install
+
+  for _hook in ghc-rebuild-doc-index.hook ghc-register.hook ghc-unregister.hook; do
+    install -D -m644 "$srcdir/$_hook" \
+      "$pkgdir/usr/share/libalpm/hooks/$_hook"
+  done
+
+  install -d -m755 "${pkgdir}"/usr/share/haskell/{register,unregister}
+
+  install -Dm644 LICENSE "$pkgdir/usr/share/licenses/$pkgname/LICENSE"
+
+  # Remove static libs and the compiler itself, but keep ghc-pkg for library (un)register
+  find "$pkgdir"/usr/lib \( -name "*.a" -o -name "*.p_hi" \) -delete
+
+  install -Dm644 utils/completion/ghc.bash \
+    "$pkgdir/usr/share/bash-completion/completions/ghc"
+}

Copied: ghc/repos/community-testing-x86_64/ghc-rebuild-doc-index.hook (from rev 242136, ghc/trunk/ghc-rebuild-doc-index.hook)
===================================================================
--- community-testing-x86_64/ghc-rebuild-doc-index.hook	                        (rev 0)
+++ community-testing-x86_64/ghc-rebuild-doc-index.hook	2017-07-03 09:28:48 UTC (rev 242139)
@@ -0,0 +1,14 @@
+[Trigger]
+Type = File
+Operation = Install
+Operation = Upgrade
+Operation = Remove
+Target = usr/share/doc/ghc/html/libraries/*
+Target = !usr/share/doc/ghc/html/libraries/index.html
+
+[Action]
+Description = Rebuilding Haskell doc index...
+When = PostTransaction
+Exec = /bin/bash -c "cd /usr/share/doc/ghc/html/libraries && ./gen_contents_index"
+Depends = ghc
+Depends = bash

Copied: ghc/repos/community-testing-x86_64/ghc-register.hook (from rev 242136, ghc/trunk/ghc-register.hook)
===================================================================
--- community-testing-x86_64/ghc-register.hook	                        (rev 0)
+++ community-testing-x86_64/ghc-register.hook	2017-07-03 09:28:48 UTC (rev 242139)
@@ -0,0 +1,12 @@
+[Trigger]
+Type = File
+Operation = Install
+Operation = Upgrade
+Target = usr/share/haskell/register/*.sh
+
+[Action]
+Description = Registering Haskell modules...
+When = PostTransaction
+Exec = /bin/sh -c 'while read -r f; do /bin/sh "/$f" 2>&1 >/dev/null ; done'
+Depends = ghc
+NeedsTargets

Copied: ghc/repos/community-testing-x86_64/ghc-unregister.hook (from rev 242137, ghc/trunk/ghc-unregister.hook)
===================================================================
--- community-testing-x86_64/ghc-unregister.hook	                        (rev 0)
+++ community-testing-x86_64/ghc-unregister.hook	2017-07-03 09:28:48 UTC (rev 242139)
@@ -0,0 +1,12 @@
+[Trigger]
+Type = File
+Operation = Upgrade
+Operation = Remove
+Target = usr/share/haskell/unregister/*.sh
+
+[Action]
+Description = Unregistering Haskell modules...
+When = PreTransaction
+Exec = /bin/sh -c 'while read -r f; do /bin/sh "/$f" 2>&1 >/dev/null ; done'
+Depends = ghc
+NeedsTargets

Copied: ghc/repos/community-testing-x86_64/ghc.install (from rev 242138, ghc/trunk/ghc.install)
===================================================================
--- community-testing-x86_64/ghc.install	                        (rev 0)
+++ community-testing-x86_64/ghc.install	2017-07-03 09:28:48 UTC (rev 242139)
@@ -0,0 +1,10 @@
+pre_upgrade() {
+  echo '==> Unregistering cabalized packages...'
+  [[ -d /usr/share/haskell ]] && find /usr/share/haskell -maxdepth 2 -name 'unregister.sh' -exec {} \;
+  echo '==> Done.'
+}
+
+post_upgrade() {
+  echo '==> All cabalized packages need to be reinstalled now.'
+  echo '==> See /usr/share/haskell/ for a tentative list of affected packages.'
+}

Copied: ghc/repos/community-testing-x86_64/print-provides-replaces.sh (from rev 242138, ghc/trunk/print-provides-replaces.sh)
===================================================================
--- community-testing-x86_64/print-provides-replaces.sh	                        (rev 0)
+++ community-testing-x86_64/print-provides-replaces.sh	2017-07-03 09:28:48 UTC (rev 242139)
@@ -0,0 +1,45 @@
+#!/bin/bash
+
+. PKGBUILD
+
+if [[ ! -d src/ghc-${pkgver}/libraries ]]; then
+  echo "error: no directory src/ghc-${pkgver}/libraries: You must extract the source tarball under src/"
+  exit 1
+fi
+
+declare -A exclude
+# no Win32 cause we're not building on windows
+exclude['Win32']=1
+# no integer-simple because we use integer-gmp
+exclude['integer-simple']=1
+# extract excluded libraries from ghc.mk
+for exclude_pkg in $(sed 's/PKGS_THAT_ARE_INTREE_ONLY := //p' -n src/ghc-${pkgver}/ghc.mk); do
+  exclude[${exclude_pkg}]=1
+done
+
+cd src/ghc-${pkgver}/libraries
+
+# $1 is the name of the variable
+# $2 is the string for the test, either '=' or '<'
+print_var() {
+  printf "$1=("
+  for path in $(ls ./*/*.cabal); do
+    dirname=$(echo $path | awk -F '/' '{ print $2 }')
+    cabalfile=$(echo $path | awk -F '/' '{ print $3 }')
+    cabalname=$(basename $cabalfile .cabal)
+    [[ ${exclude[${dirname}]} ]] && continue
+    version=$(awk 'tolower($0) ~ /^version:/ {print $2 }' $path)
+    printf "'haskell-$cabalname"
+    [[ -n "$2" ]] && printf "$2$version"
+    printf "'\n          "
+  done
+  # also add cabal
+  version=$(awk 'tolower($0) ~ /^version:/ { print $2 }' Cabal/Cabal/Cabal.cabal)
+  printf "'haskell-cabal"
+  [[ -n "$2" ]] && printf "$2$version"
+  printf "'\n          "
+  echo -e '\b)'
+}
+
+print_var 'provides' '='
+print_var 'replaces'



More information about the arch-commits mailing list