Merge pull request #183007 from NixOS/haskell-updates
haskellPackages: update stackage and hackage
This commit is contained in:
commit
016913f3da
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"commit": "155a57bcfc019c9972a44be54a407d0329dfb436",
|
"commit": "c58387b71e19d6dd43bbade8f84d6a44b6418e24",
|
||||||
"url": "https://github.com/commercialhaskell/all-cabal-hashes/archive/155a57bcfc019c9972a44be54a407d0329dfb436.tar.gz",
|
"url": "https://github.com/commercialhaskell/all-cabal-hashes/archive/c58387b71e19d6dd43bbade8f84d6a44b6418e24.tar.gz",
|
||||||
"sha256": "17pqq15b936gf8vm1lb1kmnnlmjd61a5bfld9v3cs7ydz764kg8w",
|
"sha256": "0xdvqn4392l65ns4wm47c8nyp1s7al4i506927dmkzz85m3hvyn0",
|
||||||
"msg": "Update from Hackage at 2022-07-21T21:13:45Z"
|
"msg": "Update from Hackage at 2022-07-26T16:57:53Z"
|
||||||
}
|
}
|
||||||
|
381
pkgs/development/compilers/ghc/9.4.1.nix
Normal file
381
pkgs/development/compilers/ghc/9.4.1.nix
Normal file
@ -0,0 +1,381 @@
|
|||||||
|
# Preliminary GHC 9.4.1 expression using the make build system.
|
||||||
|
# TODO(@sternenseemann): port to hadrian, so we are prepared for 9.6
|
||||||
|
# where make support will be dropped.
|
||||||
|
{ lib, stdenv, pkgsBuildTarget, pkgsHostTarget, targetPackages
|
||||||
|
|
||||||
|
# build-tools
|
||||||
|
, bootPkgs
|
||||||
|
, autoconf, automake, coreutils, fetchpatch, fetchurl, perl, python3, m4, sphinx
|
||||||
|
, xattr, autoSignDarwinBinariesHook
|
||||||
|
, bash
|
||||||
|
|
||||||
|
, libiconv ? null, ncurses
|
||||||
|
, glibcLocales ? null
|
||||||
|
|
||||||
|
, # GHC can be built with system libffi or a bundled one.
|
||||||
|
libffi ? null
|
||||||
|
|
||||||
|
, useLLVM ? !(stdenv.targetPlatform.isx86
|
||||||
|
|| stdenv.targetPlatform.isPower
|
||||||
|
|| stdenv.targetPlatform.isSparc
|
||||||
|
|| (stdenv.targetPlatform.isAarch64 && stdenv.targetPlatform.isDarwin))
|
||||||
|
, # LLVM is conceptually a run-time-only depedendency, but for
|
||||||
|
# non-x86, we need LLVM to bootstrap later stages, so it becomes a
|
||||||
|
# build-time dependency too.
|
||||||
|
buildTargetLlvmPackages, llvmPackages
|
||||||
|
|
||||||
|
, # If enabled, GHC will be built with the GPL-free but slightly slower native
|
||||||
|
# bignum backend instead of the faster but GPLed gmp backend.
|
||||||
|
enableNativeBignum ? !(lib.meta.availableOn stdenv.hostPlatform gmp)
|
||||||
|
, gmp
|
||||||
|
|
||||||
|
, # If enabled, use -fPIC when compiling static libs.
|
||||||
|
enableRelocatedStaticLibs ? stdenv.targetPlatform != stdenv.hostPlatform
|
||||||
|
|
||||||
|
# aarch64 outputs otherwise exceed 2GB limit
|
||||||
|
, enableProfiledLibs ? !stdenv.targetPlatform.isAarch64
|
||||||
|
|
||||||
|
, # Whether to build dynamic libs for the standard library (on the target
|
||||||
|
# platform). Static libs are always built.
|
||||||
|
enableShared ? with stdenv.targetPlatform; !isWindows && !useiOSPrebuilt && !isStatic
|
||||||
|
|
||||||
|
, # Whether to build terminfo.
|
||||||
|
enableTerminfo ? !stdenv.targetPlatform.isWindows
|
||||||
|
|
||||||
|
, # What flavour to build. An empty string indicates no
|
||||||
|
# specific flavour and falls back to ghc default values.
|
||||||
|
ghcFlavour ? lib.optionalString (stdenv.targetPlatform != stdenv.hostPlatform)
|
||||||
|
(if useLLVM then "perf-cross" else "perf-cross-ncg")
|
||||||
|
|
||||||
|
, # Whether to build sphinx documentation.
|
||||||
|
enableDocs ? (
|
||||||
|
# Docs disabled for musl and cross because it's a large task to keep
|
||||||
|
# all `sphinx` dependencies building in those environments.
|
||||||
|
# `sphinx` pulls in among others:
|
||||||
|
# Ruby, Python, Perl, Rust, OpenGL, Xorg, gtk, LLVM.
|
||||||
|
(stdenv.targetPlatform == stdenv.hostPlatform)
|
||||||
|
&& !stdenv.hostPlatform.isMusl
|
||||||
|
)
|
||||||
|
|
||||||
|
, enableHaddockProgram ?
|
||||||
|
# Disabled for cross; see note [HADDOCK_DOCS].
|
||||||
|
(stdenv.targetPlatform == stdenv.hostPlatform)
|
||||||
|
|
||||||
|
, # Whether to disable the large address space allocator
|
||||||
|
# necessary fix for iOS: https://www.reddit.com/r/haskell/comments/4ttdz1/building_an_osxi386_to_iosarm64_cross_compiler/d5qvd67/
|
||||||
|
disableLargeAddressSpace ? stdenv.targetPlatform.isiOS
|
||||||
|
}:
|
||||||
|
|
||||||
|
assert !enableNativeBignum -> gmp != null;
|
||||||
|
|
||||||
|
# Cross cannot currently build the `haddock` program for silly reasons,
|
||||||
|
# see note [HADDOCK_DOCS].
|
||||||
|
assert (stdenv.targetPlatform != stdenv.hostPlatform) -> !enableHaddockProgram;
|
||||||
|
|
||||||
|
let
|
||||||
|
inherit (stdenv) buildPlatform hostPlatform targetPlatform;
|
||||||
|
|
||||||
|
inherit (bootPkgs) ghc;
|
||||||
|
|
||||||
|
# TODO(@Ericson2314) Make unconditional
|
||||||
|
targetPrefix = lib.optionalString
|
||||||
|
(targetPlatform != hostPlatform)
|
||||||
|
"${targetPlatform.config}-";
|
||||||
|
|
||||||
|
buildMK = ''
|
||||||
|
BuildFlavour = ${ghcFlavour}
|
||||||
|
ifneq \"\$(BuildFlavour)\" \"\"
|
||||||
|
include mk/flavours/\$(BuildFlavour).mk
|
||||||
|
endif
|
||||||
|
BUILD_SPHINX_HTML = ${if enableDocs then "YES" else "NO"}
|
||||||
|
BUILD_SPHINX_PDF = NO
|
||||||
|
'' +
|
||||||
|
# Note [HADDOCK_DOCS]:
|
||||||
|
# Unfortunately currently `HADDOCK_DOCS` controls both whether the `haddock`
|
||||||
|
# program is built (which we generally always want to have a complete GHC install)
|
||||||
|
# and whether it is run on the GHC sources to generate hyperlinked source code
|
||||||
|
# (which is impossible for cross-compilation); see:
|
||||||
|
# https://gitlab.haskell.org/ghc/ghc/-/issues/20077
|
||||||
|
# This implies that currently a cross-compiled GHC will never have a `haddock`
|
||||||
|
# program, so it can never generate haddocks for any packages.
|
||||||
|
# If this is solved in the future, we'd like to unconditionally
|
||||||
|
# build the haddock program (removing the `enableHaddockProgram` option).
|
||||||
|
''
|
||||||
|
HADDOCK_DOCS = ${if enableHaddockProgram then "YES" else "NO"}
|
||||||
|
# Build haddocks for boot packages with hyperlinking
|
||||||
|
EXTRA_HADDOCK_OPTS += --hyperlinked-source --quickjump
|
||||||
|
|
||||||
|
DYNAMIC_GHC_PROGRAMS = ${if enableShared then "YES" else "NO"}
|
||||||
|
BIGNUM_BACKEND = ${if enableNativeBignum then "native" else "gmp"}
|
||||||
|
'' + lib.optionalString (targetPlatform != hostPlatform) ''
|
||||||
|
Stage1Only = ${if targetPlatform.system == hostPlatform.system then "NO" else "YES"}
|
||||||
|
CrossCompilePrefix = ${targetPrefix}
|
||||||
|
'' + lib.optionalString (!enableProfiledLibs) ''
|
||||||
|
GhcLibWays = "v dyn"
|
||||||
|
'' +
|
||||||
|
# -fexternal-dynamic-refs apparently (because it's not clear from the documentation)
|
||||||
|
# makes the GHC RTS able to load static libraries, which may be needed for TemplateHaskell.
|
||||||
|
# This solution was described in https://www.tweag.io/blog/2020-09-30-bazel-static-haskell
|
||||||
|
lib.optionalString enableRelocatedStaticLibs ''
|
||||||
|
GhcLibHcOpts += -fPIC -fexternal-dynamic-refs
|
||||||
|
GhcRtsHcOpts += -fPIC -fexternal-dynamic-refs
|
||||||
|
'' + lib.optionalString targetPlatform.useAndroidPrebuilt ''
|
||||||
|
EXTRA_CC_OPTS += -std=gnu99
|
||||||
|
'';
|
||||||
|
|
||||||
|
# Splicer will pull out correct variations
|
||||||
|
libDeps = platform: lib.optional enableTerminfo ncurses
|
||||||
|
++ [libffi]
|
||||||
|
++ lib.optional (!enableNativeBignum) gmp
|
||||||
|
++ lib.optional (platform.libc != "glibc" && !targetPlatform.isWindows) libiconv;
|
||||||
|
|
||||||
|
# TODO(@sternenseemann): is buildTarget LLVM unnecessary?
|
||||||
|
# GHC doesn't seem to have {LLC,OPT}_HOST
|
||||||
|
toolsForTarget = [
|
||||||
|
pkgsBuildTarget.targetPackages.stdenv.cc
|
||||||
|
] ++ lib.optional useLLVM buildTargetLlvmPackages.llvm;
|
||||||
|
|
||||||
|
targetCC = builtins.head toolsForTarget;
|
||||||
|
|
||||||
|
# Sometimes we have to dispatch between the bintools wrapper and the unwrapped
|
||||||
|
# derivation for certain tools depending on the platform.
|
||||||
|
bintoolsFor = {
|
||||||
|
# GHC needs install_name_tool on all darwin platforms. On aarch64-darwin it is
|
||||||
|
# part of the bintools wrapper (due to codesigning requirements), but not on
|
||||||
|
# x86_64-darwin.
|
||||||
|
install_name_tool =
|
||||||
|
if stdenv.targetPlatform.isAarch64
|
||||||
|
then targetCC.bintools
|
||||||
|
else targetCC.bintools.bintools;
|
||||||
|
# Same goes for strip.
|
||||||
|
strip =
|
||||||
|
# TODO(@sternenseemann): also use wrapper if linker == "bfd" or "gold"
|
||||||
|
if stdenv.targetPlatform.isAarch64 && stdenv.targetPlatform.isDarwin
|
||||||
|
then targetCC.bintools
|
||||||
|
else targetCC.bintools.bintools;
|
||||||
|
};
|
||||||
|
|
||||||
|
# Use gold either following the default, or to avoid the BFD linker due to some bugs / perf issues.
|
||||||
|
# But we cannot avoid BFD when using musl libc due to https://sourceware.org/bugzilla/show_bug.cgi?id=23856
|
||||||
|
# see #84670 and #49071 for more background.
|
||||||
|
useLdGold = targetPlatform.linker == "gold" ||
|
||||||
|
(targetPlatform.linker == "bfd" && (targetCC.bintools.bintools.hasGold or false) && !targetPlatform.isMusl);
|
||||||
|
|
||||||
|
# Makes debugging easier to see which variant is at play in `nix-store -q --tree`.
|
||||||
|
variantSuffix = lib.concatStrings [
|
||||||
|
(lib.optionalString stdenv.hostPlatform.isMusl "-musl")
|
||||||
|
(lib.optionalString enableNativeBignum "-native-bignum")
|
||||||
|
];
|
||||||
|
|
||||||
|
in
|
||||||
|
|
||||||
|
# C compiler, bintools and LLVM are used at build time, but will also leak into
|
||||||
|
# the resulting GHC's settings file and used at runtime. This means that we are
|
||||||
|
# currently only able to build GHC if hostPlatform == buildPlatform.
|
||||||
|
assert targetCC == pkgsHostTarget.targetPackages.stdenv.cc;
|
||||||
|
assert buildTargetLlvmPackages.llvm == llvmPackages.llvm;
|
||||||
|
assert stdenv.targetPlatform.isDarwin -> buildTargetLlvmPackages.clang == llvmPackages.clang;
|
||||||
|
|
||||||
|
stdenv.mkDerivation (rec {
|
||||||
|
version = "9.4.0.20220721";
|
||||||
|
pname = "${targetPrefix}ghc${variantSuffix}";
|
||||||
|
|
||||||
|
src = fetchurl {
|
||||||
|
url = "https://downloads.haskell.org/ghc/9.4.1-rc1/ghc-${version}-src.tar.xz";
|
||||||
|
sha256 = "bca8c52f76d8747a66291181de2de7bdf9ff80093808fe39bf5cbff0f116c426";
|
||||||
|
};
|
||||||
|
|
||||||
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
|
outputs = [ "out" "doc" ];
|
||||||
|
|
||||||
|
patches = [
|
||||||
|
# fix hyperlinked haddock sources: https://github.com/haskell/haddock/pull/1482
|
||||||
|
(fetchpatch {
|
||||||
|
url = "https://patch-diff.githubusercontent.com/raw/haskell/haddock/pull/1482.patch";
|
||||||
|
sha256 = "sha256-8w8QUCsODaTvknCDGgTfFNZa8ZmvIKaKS+2ZJZ9foYk=";
|
||||||
|
extraPrefix = "utils/haddock/";
|
||||||
|
stripLen = 1;
|
||||||
|
})
|
||||||
|
];
|
||||||
|
|
||||||
|
postPatch = "patchShebangs .";
|
||||||
|
|
||||||
|
# GHC needs the locale configured during the Haddock phase.
|
||||||
|
LANG = "en_US.UTF-8";
|
||||||
|
|
||||||
|
# GHC is a bit confused on its cross terminology.
|
||||||
|
# TODO(@sternenseemann): investigate coreutils dependencies and pass absolute paths
|
||||||
|
preConfigure = ''
|
||||||
|
for env in $(env | grep '^TARGET_' | sed -E 's|\+?=.*||'); do
|
||||||
|
export "''${env#TARGET_}=''${!env}"
|
||||||
|
done
|
||||||
|
# GHC is a bit confused on its cross terminology, as these would normally be
|
||||||
|
# the *host* tools.
|
||||||
|
export CC="${targetCC}/bin/${targetCC.targetPrefix}cc"
|
||||||
|
export CXX="${targetCC}/bin/${targetCC.targetPrefix}c++"
|
||||||
|
# Use gold to work around https://sourceware.org/bugzilla/show_bug.cgi?id=16177
|
||||||
|
export LD="${targetCC.bintools}/bin/${targetCC.bintools.targetPrefix}ld${lib.optionalString useLdGold ".gold"}"
|
||||||
|
export AS="${targetCC.bintools.bintools}/bin/${targetCC.bintools.targetPrefix}as"
|
||||||
|
export AR="${targetCC.bintools.bintools}/bin/${targetCC.bintools.targetPrefix}ar"
|
||||||
|
export NM="${targetCC.bintools.bintools}/bin/${targetCC.bintools.targetPrefix}nm"
|
||||||
|
export RANLIB="${targetCC.bintools.bintools}/bin/${targetCC.bintools.targetPrefix}ranlib"
|
||||||
|
export READELF="${targetCC.bintools.bintools}/bin/${targetCC.bintools.targetPrefix}readelf"
|
||||||
|
export STRIP="${bintoolsFor.strip}/bin/${bintoolsFor.strip.targetPrefix}strip"
|
||||||
|
'' + lib.optionalString (stdenv.targetPlatform.linker == "cctools") ''
|
||||||
|
export OTOOL="${targetCC.bintools.bintools}/bin/${targetCC.bintools.targetPrefix}otool"
|
||||||
|
export INSTALL_NAME_TOOL="${bintoolsFor.install_name_tool}/bin/${bintoolsFor.install_name_tool.targetPrefix}install_name_tool"
|
||||||
|
'' + lib.optionalString useLLVM ''
|
||||||
|
export LLC="${lib.getBin buildTargetLlvmPackages.llvm}/bin/llc"
|
||||||
|
export OPT="${lib.getBin buildTargetLlvmPackages.llvm}/bin/opt"
|
||||||
|
'' + lib.optionalString (useLLVM && stdenv.targetPlatform.isDarwin) ''
|
||||||
|
# LLVM backend on Darwin needs clang: https://downloads.haskell.org/~ghc/latest/docs/html/users_guide/codegens.html#llvm-code-generator-fllvm
|
||||||
|
export CLANG="${buildTargetLlvmPackages.clang}/bin/${buildTargetLlvmPackages.clang.targetPrefix}clang"
|
||||||
|
'' + ''
|
||||||
|
|
||||||
|
echo -n "${buildMK}" > mk/build.mk
|
||||||
|
# GHC 9.4.1-rc1 tarball is not properly prepared, also the boot script has been renamed
|
||||||
|
# https://gitlab.haskell.org/ghc/ghc/-/issues/21626#note_444654
|
||||||
|
# TODO(@sternenseemann): make source-dist rules include all boot-generated files
|
||||||
|
./boot.source
|
||||||
|
|
||||||
|
# Too restrictive upper bound on Cabal the make build system chokes on
|
||||||
|
# XXX(@sternenseemann): this should be upstreamed
|
||||||
|
substituteInPlace utils/ghc-cabal/ghc-cabal.cabal --replace "3.8" "3.9"
|
||||||
|
|
||||||
|
sed -i -e 's|-isysroot /Developer/SDKs/MacOSX10.5.sdk||' configure
|
||||||
|
'' + lib.optionalString (stdenv.isLinux && hostPlatform.libc == "glibc") ''
|
||||||
|
export LOCALE_ARCHIVE="${glibcLocales}/lib/locale/locale-archive"
|
||||||
|
'' + lib.optionalString (!stdenv.isDarwin) ''
|
||||||
|
export NIX_LDFLAGS+=" -rpath $out/lib/ghc-${version}"
|
||||||
|
'' + lib.optionalString stdenv.isDarwin ''
|
||||||
|
export NIX_LDFLAGS+=" -no_dtrace_dof"
|
||||||
|
|
||||||
|
# GHC tries the host xattr /usr/bin/xattr by default which fails since it expects python to be 2.7
|
||||||
|
export XATTR=${lib.getBin xattr}/bin/xattr
|
||||||
|
'' + lib.optionalString targetPlatform.useAndroidPrebuilt ''
|
||||||
|
sed -i -e '5i ,("armv7a-unknown-linux-androideabi", ("e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64", "cortex-a8", ""))' llvm-targets
|
||||||
|
'' + lib.optionalString targetPlatform.isMusl ''
|
||||||
|
echo "patching llvm-targets for musl targets..."
|
||||||
|
echo "Cloning these existing '*-linux-gnu*' targets:"
|
||||||
|
grep linux-gnu llvm-targets | sed 's/^/ /'
|
||||||
|
echo "(go go gadget sed)"
|
||||||
|
sed -i 's,\(^.*linux-\)gnu\(.*\)$,\0\n\1musl\2,' llvm-targets
|
||||||
|
echo "llvm-targets now contains these '*-linux-musl*' targets:"
|
||||||
|
grep linux-musl llvm-targets | sed 's/^/ /'
|
||||||
|
|
||||||
|
echo "And now patching to preserve '-musleabi' as done with '-gnueabi'"
|
||||||
|
# (aclocal.m4 is actual source, but patch configure as well since we don't re-gen)
|
||||||
|
for x in configure aclocal.m4; do
|
||||||
|
substituteInPlace $x \
|
||||||
|
--replace '*-android*|*-gnueabi*)' \
|
||||||
|
'*-android*|*-gnueabi*|*-musleabi*)'
|
||||||
|
done
|
||||||
|
'';
|
||||||
|
|
||||||
|
# TODO(@Ericson2314): Always pass "--target" and always prefix.
|
||||||
|
configurePlatforms = [ "build" "host" ]
|
||||||
|
++ lib.optional (targetPlatform != hostPlatform) "target";
|
||||||
|
|
||||||
|
# `--with` flags for libraries needed for RTS linker
|
||||||
|
configureFlags = [
|
||||||
|
"--datadir=$doc/share/doc/ghc"
|
||||||
|
"--with-curses-includes=${ncurses.dev}/include" "--with-curses-libraries=${ncurses.out}/lib"
|
||||||
|
] ++ lib.optionals (libffi != null) [
|
||||||
|
"--with-system-libffi"
|
||||||
|
"--with-ffi-includes=${targetPackages.libffi.dev}/include"
|
||||||
|
"--with-ffi-libraries=${targetPackages.libffi.out}/lib"
|
||||||
|
] ++ lib.optionals (targetPlatform == hostPlatform && !enableNativeBignum) [
|
||||||
|
"--with-gmp-includes=${targetPackages.gmp.dev}/include"
|
||||||
|
"--with-gmp-libraries=${targetPackages.gmp.out}/lib"
|
||||||
|
] ++ lib.optionals (targetPlatform == hostPlatform && hostPlatform.libc != "glibc" && !targetPlatform.isWindows) [
|
||||||
|
"--with-iconv-includes=${libiconv}/include"
|
||||||
|
"--with-iconv-libraries=${libiconv}/lib"
|
||||||
|
] ++ lib.optionals (targetPlatform != hostPlatform) [
|
||||||
|
"--enable-bootstrap-with-devel-snapshot"
|
||||||
|
] ++ lib.optionals useLdGold [
|
||||||
|
"CFLAGS=-fuse-ld=gold"
|
||||||
|
"CONF_GCC_LINKER_OPTS_STAGE1=-fuse-ld=gold"
|
||||||
|
"CONF_GCC_LINKER_OPTS_STAGE2=-fuse-ld=gold"
|
||||||
|
] ++ lib.optionals (disableLargeAddressSpace) [
|
||||||
|
"--disable-large-address-space"
|
||||||
|
];
|
||||||
|
|
||||||
|
# Make sure we never relax`$PATH` and hooks support for compatibility.
|
||||||
|
strictDeps = true;
|
||||||
|
|
||||||
|
# Don’t add -liconv to LDFLAGS automatically so that GHC will add it itself.
|
||||||
|
dontAddExtraLibs = true;
|
||||||
|
|
||||||
|
nativeBuildInputs = [
|
||||||
|
perl autoconf automake m4 python3
|
||||||
|
ghc bootPkgs.alex bootPkgs.happy bootPkgs.hscolour
|
||||||
|
] ++ lib.optionals (stdenv.isDarwin && stdenv.isAarch64) [
|
||||||
|
autoSignDarwinBinariesHook
|
||||||
|
] ++ lib.optionals enableDocs [
|
||||||
|
sphinx
|
||||||
|
];
|
||||||
|
|
||||||
|
# For building runtime libs
|
||||||
|
depsBuildTarget = toolsForTarget;
|
||||||
|
|
||||||
|
buildInputs = [ perl bash ] ++ (libDeps hostPlatform);
|
||||||
|
|
||||||
|
depsTargetTarget = map lib.getDev (libDeps targetPlatform);
|
||||||
|
depsTargetTargetPropagated = map (lib.getOutput "out") (libDeps targetPlatform);
|
||||||
|
|
||||||
|
# required, because otherwise all symbols from HSffi.o are stripped, and
|
||||||
|
# that in turn causes GHCi to abort
|
||||||
|
stripDebugFlags = [ "-S" ] ++ lib.optional (!targetPlatform.isDarwin) "--keep-file-symbols";
|
||||||
|
|
||||||
|
checkTarget = "test";
|
||||||
|
|
||||||
|
hardeningDisable =
|
||||||
|
[ "format" ]
|
||||||
|
# In nixpkgs, musl based builds currently enable `pie` hardening by default
|
||||||
|
# (see `defaultHardeningFlags` in `make-derivation.nix`).
|
||||||
|
# But GHC cannot currently produce outputs that are ready for `-pie` linking.
|
||||||
|
# Thus, disable `pie` hardening, otherwise `recompile with -fPIE` errors appear.
|
||||||
|
# See:
|
||||||
|
# * https://github.com/NixOS/nixpkgs/issues/129247
|
||||||
|
# * https://gitlab.haskell.org/ghc/ghc/-/issues/19580
|
||||||
|
++ lib.optional stdenv.targetPlatform.isMusl "pie";
|
||||||
|
|
||||||
|
# big-parallel allows us to build with more than 2 cores on
|
||||||
|
# Hydra which already warrants a significant speedup
|
||||||
|
requiredSystemFeatures = [ "big-parallel" ];
|
||||||
|
|
||||||
|
postInstall = ''
|
||||||
|
# Install the bash completion file.
|
||||||
|
install -D -m 444 utils/completion/ghc.bash $out/share/bash-completion/completions/${targetPrefix}ghc
|
||||||
|
'';
|
||||||
|
|
||||||
|
passthru = {
|
||||||
|
inherit bootPkgs targetPrefix;
|
||||||
|
|
||||||
|
inherit llvmPackages;
|
||||||
|
inherit enableShared;
|
||||||
|
|
||||||
|
# This is used by the haskell builder to query
|
||||||
|
# the presence of the haddock program.
|
||||||
|
hasHaddock = enableHaddockProgram;
|
||||||
|
|
||||||
|
# Our Cabal compiler name
|
||||||
|
haskellCompilerName = "ghc-${version}";
|
||||||
|
};
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
homepage = "http://haskell.org/ghc";
|
||||||
|
description = "The Glasgow Haskell Compiler";
|
||||||
|
maintainers = with lib.maintainers; [
|
||||||
|
guibou
|
||||||
|
] ++ lib.teams.haskell.members;
|
||||||
|
timeout = 24 * 3600;
|
||||||
|
inherit (ghc.meta) license platforms;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // lib.optionalAttrs targetPlatform.useAndroidPrebuilt {
|
||||||
|
dontStrip = true;
|
||||||
|
dontPatchELF = true;
|
||||||
|
noAuditTmpdir = true;
|
||||||
|
})
|
@ -8,10 +8,10 @@
|
|||||||
}:
|
}:
|
||||||
mkDerivation {
|
mkDerivation {
|
||||||
pname = "cabal2nix";
|
pname = "cabal2nix";
|
||||||
version = "unstable-2022-07-17";
|
version = "unstable-2022-07-22";
|
||||||
src = fetchzip {
|
src = fetchzip {
|
||||||
url = "https://github.com/NixOS/cabal2nix/archive/6c6fa480dd535a8a6909b60e1130a6b5bfc2a2c4.tar.gz";
|
url = "https://github.com/NixOS/cabal2nix/archive/e00ab24821be85cb025432f8e9c4ff56dbb00a81.tar.gz";
|
||||||
sha256 = "19dagxhj1aflhf19xab8yss5mia6kfpghn4h0na8zshqab8xxgrd";
|
sha256 = "11a5l0fdj67bpqv30af4v5zxr3c7n9p81pfs4c0d3w65bmr9sa1y";
|
||||||
};
|
};
|
||||||
isLibrary = true;
|
isLibrary = true;
|
||||||
isExecutable = true;
|
isExecutable = true;
|
||||||
|
@ -99,7 +99,7 @@ self: super: {
|
|||||||
name = "git-annex-${super.git-annex.version}-src";
|
name = "git-annex-${super.git-annex.version}-src";
|
||||||
url = "git://git-annex.branchable.com/";
|
url = "git://git-annex.branchable.com/";
|
||||||
rev = "refs/tags/" + super.git-annex.version;
|
rev = "refs/tags/" + super.git-annex.version;
|
||||||
sha256 = "0pr2fnaq3fa6lcly39xssl89v65h0wa26ikv5g30fm8y6z5rkqqd";
|
sha256 = "0p9qd7yasdji5kwxn4d0hrv9hnxbzfsczknldh8jav3ynhg8k6c9";
|
||||||
# delete android and Android directories which cause issues on
|
# delete android and Android directories which cause issues on
|
||||||
# darwin (case insensitive directory). Since we don't need them
|
# darwin (case insensitive directory). Since we don't need them
|
||||||
# during the build process, we can delete it to prevent a hash
|
# during the build process, we can delete it to prevent a hash
|
||||||
@ -2404,26 +2404,13 @@ self: super: {
|
|||||||
# https://github.com/system-f/validation/issues/57
|
# https://github.com/system-f/validation/issues/57
|
||||||
validation = doJailbreak super.validation;
|
validation = doJailbreak super.validation;
|
||||||
|
|
||||||
# aws upstream seems to lack the necessary maintenance at the moment, luckily
|
|
||||||
# Joey Hess seems to have already looked into building git-annex with aeson 2.0
|
|
||||||
# https://github.com/aristidb/aws/issues/275
|
|
||||||
aws = overrideCabal (drv: {
|
|
||||||
patches = drv.patches or [] ++ [
|
|
||||||
(fetchpatch {
|
|
||||||
name = "aws-aeson-2.0-compat.patch";
|
|
||||||
url = "https://github.com/aristidb/aws/pull/277/commits/7af7586c5d244d07f77d49e5fdc739e6e8e54816.patch";
|
|
||||||
sha256 = "1bsiyk1k671rwlyflka2whq972h72cwscrxkr9n2wzhxp70ap3g3";
|
|
||||||
excludes = [ "aws.cabal" ];
|
|
||||||
})
|
|
||||||
];
|
|
||||||
# needs aws credentials, jailbreak for base16-bytestring
|
|
||||||
doCheck = false;
|
|
||||||
jailbreak = true;
|
|
||||||
}) super.aws;
|
|
||||||
|
|
||||||
# 2022-03-16: strict upper bounds https://github.com/monadfix/shower/issues/18
|
# 2022-03-16: strict upper bounds https://github.com/monadfix/shower/issues/18
|
||||||
shower = doJailbreak (dontCheck super.shower);
|
shower = doJailbreak (dontCheck super.shower);
|
||||||
|
|
||||||
|
# Doesn't compile with HTF 0.15
|
||||||
|
# https://github.com/andrewufrank/uniform-error/issues/1
|
||||||
|
uniform-error = dontCheck super.uniform-error;
|
||||||
|
|
||||||
# The shipped Setup.hs file is broken.
|
# The shipped Setup.hs file is broken.
|
||||||
csv = overrideCabal (drv: { preCompileBuildDriver = "rm Setup.hs"; }) super.csv;
|
csv = overrideCabal (drv: { preCompileBuildDriver = "rm Setup.hs"; }) super.csv;
|
||||||
|
|
||||||
|
51
pkgs/development/haskell-modules/configuration-ghc-9.4.x.nix
Normal file
51
pkgs/development/haskell-modules/configuration-ghc-9.4.x.nix
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
{ pkgs, haskellLib }:
|
||||||
|
|
||||||
|
let
|
||||||
|
inherit (pkgs) fetchpatch lib;
|
||||||
|
inherit (lib) throwIfNot versionOlder;
|
||||||
|
in
|
||||||
|
|
||||||
|
self: super: {
|
||||||
|
llvmPackages = lib.dontRecurseIntoAttrs self.ghc.llvmPackages;
|
||||||
|
|
||||||
|
# Disable GHC core libraries.
|
||||||
|
array = null;
|
||||||
|
base = null;
|
||||||
|
binary = null;
|
||||||
|
bytestring = null;
|
||||||
|
Cabal = null;
|
||||||
|
Cabal-syntax = null;
|
||||||
|
containers = null;
|
||||||
|
deepseq = null;
|
||||||
|
directory = null;
|
||||||
|
exceptions = null;
|
||||||
|
filepath = null;
|
||||||
|
ghc-bignum = null;
|
||||||
|
ghc-boot = null;
|
||||||
|
ghc-boot-th = null;
|
||||||
|
ghc-compact = null;
|
||||||
|
ghc-heap = null;
|
||||||
|
ghc-prim = null;
|
||||||
|
ghci = null;
|
||||||
|
haskeline = null;
|
||||||
|
hpc = null;
|
||||||
|
integer-gmp = null;
|
||||||
|
libiserv = null;
|
||||||
|
mtl = null;
|
||||||
|
parsec = null;
|
||||||
|
pretty = null;
|
||||||
|
process = null;
|
||||||
|
rts = null;
|
||||||
|
stm = null;
|
||||||
|
system-cxx-std-lib = null;
|
||||||
|
template-haskell = null;
|
||||||
|
# GHC only builds terminfo if it is a native compiler
|
||||||
|
terminfo = if pkgs.stdenv.hostPlatform == pkgs.stdenv.buildPlatform then null else self.terminfo_0_4_1_5;
|
||||||
|
text = null;
|
||||||
|
time = null;
|
||||||
|
transformers = null;
|
||||||
|
unix = null;
|
||||||
|
# GHC only bundles the xhtml library if haddock is enabled, check if this is
|
||||||
|
# still the case when updating: https://gitlab.haskell.org/ghc/ghc/-/blob/0198841877f6f04269d6050892b98b5c3807ce4c/ghc.mk#L463
|
||||||
|
xhtml = if self.ghc.hasHaddock or true then null else self.xhtml_3000_2_2_1;
|
||||||
|
}
|
@ -543,6 +543,7 @@ broken-packages:
|
|||||||
- cabalgraph
|
- cabalgraph
|
||||||
- cabal-graphdeps
|
- cabal-graphdeps
|
||||||
- cabal-helper
|
- cabal-helper
|
||||||
|
- cabal-hoogle
|
||||||
- Cabal-ide-backend
|
- Cabal-ide-backend
|
||||||
- cabal-info
|
- cabal-info
|
||||||
- cabal-install-bundle
|
- cabal-install-bundle
|
||||||
@ -1259,6 +1260,7 @@ broken-packages:
|
|||||||
- ebnf-bff
|
- ebnf-bff
|
||||||
- eccrypto
|
- eccrypto
|
||||||
- ecma262
|
- ecma262
|
||||||
|
- ecta
|
||||||
- ecu
|
- ecu
|
||||||
- eddie
|
- eddie
|
||||||
- ede
|
- ede
|
||||||
@ -1304,6 +1306,7 @@ broken-packages:
|
|||||||
- emailaddress
|
- emailaddress
|
||||||
- email-header
|
- email-header
|
||||||
- email-postmark
|
- email-postmark
|
||||||
|
- embed-config
|
||||||
- embla
|
- embla
|
||||||
- emgm
|
- emgm
|
||||||
- Emping
|
- Emping
|
||||||
@ -1502,7 +1505,6 @@ broken-packages:
|
|||||||
- fix-symbols-gitit
|
- fix-symbols-gitit
|
||||||
- fizzbuzz
|
- fizzbuzz
|
||||||
- fizzbuzz-as-a-service
|
- fizzbuzz-as-a-service
|
||||||
- flac
|
|
||||||
- flaccuraterip
|
- flaccuraterip
|
||||||
- flamethrower
|
- flamethrower
|
||||||
- flamingra
|
- flamingra
|
||||||
@ -2867,6 +2869,7 @@ broken-packages:
|
|||||||
- koellner-phonetic
|
- koellner-phonetic
|
||||||
- koneko
|
- koneko
|
||||||
- Konf
|
- Konf
|
||||||
|
- konnakol
|
||||||
- kontra-config
|
- kontra-config
|
||||||
- koofr-client
|
- koofr-client
|
||||||
- korea-holidays
|
- korea-holidays
|
||||||
@ -3537,7 +3540,6 @@ broken-packages:
|
|||||||
- newtype-th
|
- newtype-th
|
||||||
- next-ref
|
- next-ref
|
||||||
- nextstep-plist
|
- nextstep-plist
|
||||||
- nfc
|
|
||||||
- NGrams
|
- NGrams
|
||||||
- niagra
|
- niagra
|
||||||
- nibblestring
|
- nibblestring
|
||||||
@ -4015,6 +4017,7 @@ broken-packages:
|
|||||||
- postgres-embedded
|
- postgres-embedded
|
||||||
- PostgreSQL
|
- PostgreSQL
|
||||||
- postgresql-lo-stream
|
- postgresql-lo-stream
|
||||||
|
- postgresql-ltree
|
||||||
- postgresql-named
|
- postgresql-named
|
||||||
- postgresql-query
|
- postgresql-query
|
||||||
- postgresql-resilient
|
- postgresql-resilient
|
||||||
@ -5492,6 +5495,7 @@ broken-packages:
|
|||||||
- validated-types
|
- validated-types
|
||||||
- Validation
|
- Validation
|
||||||
- validations
|
- validations
|
||||||
|
- validity-network-uri
|
||||||
- valid-names
|
- valid-names
|
||||||
- value-supply
|
- value-supply
|
||||||
- vampire
|
- vampire
|
||||||
|
@ -165,6 +165,8 @@ package-maintainers:
|
|||||||
- spago
|
- spago
|
||||||
- stack
|
- stack
|
||||||
- termonad
|
- termonad
|
||||||
|
centromere:
|
||||||
|
- nfc
|
||||||
dalpd:
|
dalpd:
|
||||||
- ghc-vis
|
- ghc-vis
|
||||||
- svgcairo
|
- svgcairo
|
||||||
|
@ -304,6 +304,7 @@ dont-distribute-packages:
|
|||||||
- PlslTools
|
- PlslTools
|
||||||
- Printf-TH
|
- Printf-TH
|
||||||
- ProbabilityMonads
|
- ProbabilityMonads
|
||||||
|
- PropaFP
|
||||||
- Pugs
|
- Pugs
|
||||||
- Pup-Events
|
- Pup-Events
|
||||||
- Pup-Events-Demo
|
- Pup-Events-Demo
|
||||||
@ -844,6 +845,7 @@ dont-distribute-packages:
|
|||||||
- bricks-rendering
|
- bricks-rendering
|
||||||
- bricks-syntax
|
- bricks-syntax
|
||||||
- bronyradiogermany-streaming
|
- bronyradiogermany-streaming
|
||||||
|
- btc-lsp
|
||||||
- btree
|
- btree
|
||||||
- buchhaltung
|
- buchhaltung
|
||||||
- buildbox-tools
|
- buildbox-tools
|
||||||
@ -1316,6 +1318,7 @@ dont-distribute-packages:
|
|||||||
- ekg-carbon
|
- ekg-carbon
|
||||||
- ekg-cloudwatch
|
- ekg-cloudwatch
|
||||||
- ekg-wai
|
- ekg-wai
|
||||||
|
- electrs-client
|
||||||
- elerea-examples
|
- elerea-examples
|
||||||
- elliptic-curve
|
- elliptic-curve
|
||||||
- elsa
|
- elsa
|
||||||
@ -1452,7 +1455,6 @@ dont-distribute-packages:
|
|||||||
- fixed-point-vector-space
|
- fixed-point-vector-space
|
||||||
- fixed-precision
|
- fixed-precision
|
||||||
- fixhs
|
- fixhs
|
||||||
- flac-picture
|
|
||||||
- flashblast
|
- flashblast
|
||||||
- flatbuffers
|
- flatbuffers
|
||||||
- flexiwrap
|
- flexiwrap
|
||||||
@ -1550,6 +1552,7 @@ dont-distribute-packages:
|
|||||||
- geniconvert
|
- geniconvert
|
||||||
- geniserver
|
- geniserver
|
||||||
- genvalidity-mergeful
|
- genvalidity-mergeful
|
||||||
|
- genvalidity-network-uri
|
||||||
- genvalidity-sydtest
|
- genvalidity-sydtest
|
||||||
- genvalidity-sydtest-aeson
|
- genvalidity-sydtest-aeson
|
||||||
- genvalidity-sydtest-hashable
|
- genvalidity-sydtest-hashable
|
||||||
@ -3120,6 +3123,7 @@ dont-distribute-packages:
|
|||||||
- poseidon
|
- poseidon
|
||||||
- poseidon-postgis
|
- poseidon-postgis
|
||||||
- postgresql-pure
|
- postgresql-pure
|
||||||
|
- postgresql-simple-ltree
|
||||||
- postgresql-simple-queue
|
- postgresql-simple-queue
|
||||||
- postgresql-simple-typed
|
- postgresql-simple-typed
|
||||||
- postgresql-tx-query
|
- postgresql-tx-query
|
||||||
@ -3194,6 +3198,7 @@ dont-distribute-packages:
|
|||||||
- pvd
|
- pvd
|
||||||
- qd-vec
|
- qd-vec
|
||||||
- qhs
|
- qhs
|
||||||
|
- qhull
|
||||||
- qr-imager
|
- qr-imager
|
||||||
- qr-repa
|
- qr-repa
|
||||||
- qtah-examples
|
- qtah-examples
|
||||||
|
@ -948,6 +948,10 @@ self: super: builtins.intersectAttrs super {
|
|||||||
] ++ (drv.patches or []);
|
] ++ (drv.patches or []);
|
||||||
}) super.graphviz;
|
}) super.graphviz;
|
||||||
|
|
||||||
|
# Test suite requires AWS access which requires both a network
|
||||||
|
# connection and payment.
|
||||||
|
aws = dontCheck super.aws;
|
||||||
|
|
||||||
# Test case tries to contact the network
|
# Test case tries to contact the network
|
||||||
http-api-data-qq = overrideCabal (drv: {
|
http-api-data-qq = overrideCabal (drv: {
|
||||||
testFlags = [
|
testFlags = [
|
||||||
@ -973,6 +977,13 @@ self: super: builtins.intersectAttrs super {
|
|||||||
'';
|
'';
|
||||||
}) super.jacinda;
|
}) super.jacinda;
|
||||||
|
|
||||||
|
nfc = overrideCabal (drv: {
|
||||||
|
isExecutable = true;
|
||||||
|
executableHaskellDepends = with self; drv.executableHaskellDepends or [] ++ [ base base16-bytestring bytestring ];
|
||||||
|
configureFlags = drv.configureFlags or [] ++ [ "-fbuild-examples" ];
|
||||||
|
enableSeparateBinOutput = true;
|
||||||
|
}) super.nfc;
|
||||||
|
|
||||||
# haskell-language-server plugins all use the same test harness so we give them what we want in this loop.
|
# haskell-language-server plugins all use the same test harness so we give them what we want in this loop.
|
||||||
} // pkgs.lib.mapAttrs
|
} // pkgs.lib.mapAttrs
|
||||||
(_: overrideCabal (drv: {
|
(_: overrideCabal (drv: {
|
||||||
|
1033
pkgs/development/haskell-modules/hackage-packages.nix
generated
1033
pkgs/development/haskell-modules/hackage-packages.nix
generated
File diff suppressed because it is too large
Load Diff
@ -16,12 +16,14 @@ let
|
|||||||
"native-bignum"
|
"native-bignum"
|
||||||
"ghc902"
|
"ghc902"
|
||||||
"ghc923"
|
"ghc923"
|
||||||
|
"ghc941"
|
||||||
"ghcHEAD"
|
"ghcHEAD"
|
||||||
];
|
];
|
||||||
|
|
||||||
nativeBignumIncludes = [
|
nativeBignumIncludes = [
|
||||||
"ghc902"
|
"ghc902"
|
||||||
"ghc923"
|
"ghc923"
|
||||||
|
"ghc941"
|
||||||
"ghcHEAD"
|
"ghcHEAD"
|
||||||
];
|
];
|
||||||
|
|
||||||
@ -153,6 +155,21 @@ in {
|
|||||||
buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12;
|
buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12;
|
||||||
llvmPackages = pkgs.llvmPackages_12;
|
llvmPackages = pkgs.llvmPackages_12;
|
||||||
};
|
};
|
||||||
|
ghc941 = callPackage ../development/compilers/ghc/9.4.1.nix {
|
||||||
|
bootPkgs =
|
||||||
|
# TODO(@sternenseemann): Package 9.0.2 bindist or wait for upstream fix
|
||||||
|
# Need to use 902 due to
|
||||||
|
# https://gitlab.haskell.org/ghc/ghc/-/issues/21914
|
||||||
|
packages.ghc902;
|
||||||
|
inherit (buildPackages.python3Packages) sphinx;
|
||||||
|
# Need to use apple's patched xattr until
|
||||||
|
# https://github.com/xattr/xattr/issues/44 and
|
||||||
|
# https://github.com/xattr/xattr/issues/55 are solved.
|
||||||
|
inherit (buildPackages.darwin) xattr autoSignDarwinBinariesHook;
|
||||||
|
# Support range >= 10 && < 14
|
||||||
|
buildTargetLlvmPackages = pkgsBuildTarget.llvmPackages_12;
|
||||||
|
llvmPackages = pkgs.llvmPackages_12;
|
||||||
|
};
|
||||||
ghcHEAD = callPackage ../development/compilers/ghc/head.nix {
|
ghcHEAD = callPackage ../development/compilers/ghc/head.nix {
|
||||||
bootPkgs =
|
bootPkgs =
|
||||||
if stdenv.hostPlatform.isPower64 && stdenv.hostPlatform.isLittleEndian then
|
if stdenv.hostPlatform.isPower64 && stdenv.hostPlatform.isLittleEndian then
|
||||||
@ -265,6 +282,11 @@ in {
|
|||||||
ghc = bh.compiler.ghc923;
|
ghc = bh.compiler.ghc923;
|
||||||
compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.2.x.nix { };
|
compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.2.x.nix { };
|
||||||
};
|
};
|
||||||
|
ghc941 = callPackage ../development/haskell-modules {
|
||||||
|
buildHaskellPackages = bh.packages.ghc941;
|
||||||
|
ghc = bh.compiler.ghc941;
|
||||||
|
compilerConfig = callPackage ../development/haskell-modules/configuration-ghc-9.4.x.nix { };
|
||||||
|
};
|
||||||
ghcHEAD = callPackage ../development/haskell-modules {
|
ghcHEAD = callPackage ../development/haskell-modules {
|
||||||
buildHaskellPackages = bh.packages.ghcHEAD;
|
buildHaskellPackages = bh.packages.ghcHEAD;
|
||||||
ghc = bh.compiler.ghcHEAD;
|
ghc = bh.compiler.ghcHEAD;
|
||||||
|
Loading…
Reference in New Issue
Block a user