diff options
author | Dennis Gosnell <cdep.illabout@gmail.com> | 2021-07-23 09:14:37 +0900 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-07-23 09:14:37 +0900 |
commit | 38fe12189506453de8e548b7149b7f0e317c9863 (patch) | |
tree | 820c4f6e2516741238180a41ebaf841300cd08cb /pkgs/development | |
parent | 1019c5c2a8c466a7dec60156e6c9803cc78d8bd5 (diff) | |
parent | 264e63477da228071f03a0b4bfd17a9f612e7bc1 (diff) | |
download | nixpkgs-38fe12189506453de8e548b7149b7f0e317c9863.tar nixpkgs-38fe12189506453de8e548b7149b7f0e317c9863.tar.gz nixpkgs-38fe12189506453de8e548b7149b7f0e317c9863.tar.bz2 nixpkgs-38fe12189506453de8e548b7149b7f0e317c9863.tar.lz nixpkgs-38fe12189506453de8e548b7149b7f0e317c9863.tar.xz nixpkgs-38fe12189506453de8e548b7149b7f0e317c9863.tar.zst nixpkgs-38fe12189506453de8e548b7149b7f0e317c9863.zip |
Merge pull request #131067 from maralorn/hackage-package-list
pkgs.haskell.package-list: init
Diffstat (limited to 'pkgs/development')
-rw-r--r-- | pkgs/development/haskell-modules/HACKING.md | 8 | ||||
-rw-r--r-- | pkgs/development/haskell-modules/package-list.nix | 19 |
2 files changed, 27 insertions, 0 deletions
diff --git a/pkgs/development/haskell-modules/HACKING.md b/pkgs/development/haskell-modules/HACKING.md index 37bd5544fe1..98ab03a0edd 100644 --- a/pkgs/development/haskell-modules/HACKING.md +++ b/pkgs/development/haskell-modules/HACKING.md @@ -241,6 +241,14 @@ When you've double-checked these points, go ahead and merge the `haskell-updates After merging, **make sure not to delete the `haskell-updates` branch**, since it causes all currently open Haskell-related pull-requests to be automatically closed on GitHub. +## Update Hackage Version Information + +After merging into master you can update what hackage displays as the current +version in NixOS for every individual package. +To do this you run `maintainers/scripts/haskell/upload-nixos-package-list-to-hackage.sh`. +See the script for how to provide credentials. Once you have configured that +running this takes only a few seconds. + ## Additional Info Here are some additional tips that didn't fit in above. diff --git a/pkgs/development/haskell-modules/package-list.nix b/pkgs/development/haskell-modules/package-list.nix new file mode 100644 index 00000000000..64f4be3a772 --- /dev/null +++ b/pkgs/development/haskell-modules/package-list.nix @@ -0,0 +1,19 @@ +{ runCommand, haskellPackages, lib, all-cabal-hashes, writeShellScript }: +let + pkgLine = name: pkg: + let + version = pkg.version or ""; + in + if version != "" then + ''"${name}","${version}","http://hydra.nixos.org/job/nixpkgs/trunk/haskellPackages.${name}.x86_64-linux"'' + else ""; + all-haskellPackages = builtins.toFile "all-haskellPackages" (lib.concatStringsSep "\n" (lib.filter (x: x != "") (lib.mapAttrsToList pkgLine haskellPackages))); +in +runCommand "hackage-package-list" { } + # This command will make a join between all packages on hackage and haskellPackages.*. + # It creates a valid csv file which can be uploaded to hackage.haskell.org. + # The call is wrapped in echo $(...) to trim trailing newline, which hackage requires. + '' + mkdir -p $out/bin + echo -n "$(tar -t -f ${all-cabal-hashes} | sed 's![^/]*/\([^/]*\)/.*!"\1"!' | sort -u | join -t , - ${all-haskellPackages})" > $out/nixos-hackage-packages.csv + '' |