summaryrefslogtreecommitdiff
path: root/utils/verify-release/verify-packages.sh
diff options
context:
space:
mode:
authorMoritz Angermann <moritz.angermann@gmail.com>2019-01-20 05:24:21 -0500
committerMarge Bot <ben+marge-bot@smart-cactus.org>2019-01-20 05:24:21 -0500
commitb137ab75ab269e043e0783e41ac704d1be5570c6 (patch)
treea946e6a11e33b32a445a096c9c28471b645d2d88 /utils/verify-release/verify-packages.sh
parentc9756dbf1ee58b117ea5c4ded45dea88030efd65 (diff)
downloadhaskell-b137ab75ab269e043e0783e41ac704d1be5570c6.tar.gz
[T16199] Adds a verify-packages scriptghc-8.9-start
Diffstat (limited to 'utils/verify-release/verify-packages.sh')
-rwxr-xr-xutils/verify-release/verify-packages.sh20
1 files changed, 20 insertions, 0 deletions
diff --git a/utils/verify-release/verify-packages.sh b/utils/verify-release/verify-packages.sh
new file mode 100755
index 0000000000..d5c6bf1bfc
--- /dev/null
+++ b/utils/verify-release/verify-packages.sh
@@ -0,0 +1,20 @@
+#!/bin/bash
+#
+# This script will verify that the packages in ghc,
+# correspond to packages on hackage.
+rm -fR ghc-packages hackage-packages package-diffs
+mkdir -p ghc-packages hackage-packages package-diffs
+# We'll skip Cabal and tarballs, while looking only at packages in libraries
+# that we reference as gitmodules.
+for lib in $(git submodule status|grep libraries|grep -v tarballs|grep -v Cabal|awk -F\ '{ print $2 }'); do
+ (cd $lib && cabal new-sdist -o ../../ghc-packages);
+done
+
+for pkg in $(cd ghc-packages && ls *.tar.gz); do
+ PKG=${pkg%%.tar.gz}
+ (cd hackage-packages && cabal get --pristine ${PKG})
+ (cd hackage-packages/${PKG} && git init && git add . && git commit -q -m "hackage packages" && rm -fR *)
+ (cd hackage-packages && tar xzf ../ghc-packages/$pkg)
+ (cd hackage-packages/${PKG} && git -c core.fileMode=false diff > ../$PKG.patch)
+done
+find hackage-packages -name "*.patch" -not -empty -type f -print -exec false {} +