2015-01-22 23:10:08 +00:00
|
|
|
# Install not only the Hoogle library and executable, but also a local Hoogle
|
|
|
|
# database which provides "Source" links to all specified 'packages' -- or the
|
|
|
|
# current Haskell Platform if no custom package set is provided.
|
|
|
|
#
|
|
|
|
# It is intended to be used in config.nix similarly to:
|
|
|
|
#
|
|
|
|
# { packageOverrides = pkgs: rec {
|
|
|
|
#
|
|
|
|
# haskellPackages =
|
|
|
|
# let callPackage = pkgs.lib.callPackageWith haskellPackages;
|
|
|
|
# in pkgs.recurseIntoAttrs (pkgs.haskellPackages.override {
|
|
|
|
# extension = self: super: {
|
|
|
|
# hoogleLocal = pkgs.haskellPackages.hoogleLocal.override {
|
|
|
|
# packages = with pkgs.haskellPackages; [
|
|
|
|
# mmorph
|
|
|
|
# monadControl
|
|
|
|
# ];
|
|
|
|
# };
|
|
|
|
# };
|
|
|
|
# });
|
|
|
|
# }}
|
|
|
|
#
|
|
|
|
# This will build mmorph and monadControl, and have the hoogle installation
|
|
|
|
# refer to their documentation via symlink so they are not garbage collected.
|
|
|
|
|
2016-02-01 04:00:43 +00:00
|
|
|
{ lib, stdenv, hoogle, rehoo, writeText
|
2015-01-22 23:10:08 +00:00
|
|
|
, ghc, packages ? [ ghc.ghc ]
|
|
|
|
}:
|
|
|
|
|
|
|
|
let
|
|
|
|
inherit (stdenv.lib) optional;
|
|
|
|
wrapper = ./hoogle-local-wrapper.sh;
|
2016-02-01 04:00:43 +00:00
|
|
|
isGhcjs = ghc.isGhcjs or false;
|
2016-02-01 05:10:45 +00:00
|
|
|
opts = lib.optionalString;
|
2016-02-01 04:00:43 +00:00
|
|
|
haddockExe =
|
|
|
|
if !isGhcjs
|
|
|
|
then "haddock"
|
|
|
|
else "haddock-ghcjs";
|
|
|
|
ghcName =
|
|
|
|
if !isGhcjs
|
|
|
|
then "ghc"
|
|
|
|
else "ghcjs";
|
|
|
|
docLibGlob =
|
|
|
|
if !isGhcjs
|
|
|
|
then ''share/doc/ghc*/html/libraries''
|
|
|
|
else ''doc/lib'';
|
|
|
|
# On GHCJS, use a stripped down version of GHC's prologue.txt
|
|
|
|
prologue =
|
|
|
|
if !isGhcjs
|
|
|
|
then "${ghc}/${docLibGlob}/prologue.txt"
|
|
|
|
else writeText "ghcjs-prologue.txt" ''
|
|
|
|
This index includes documentation for many Haskell modules.
|
|
|
|
'';
|
2015-01-22 23:10:08 +00:00
|
|
|
in
|
|
|
|
stdenv.mkDerivation {
|
|
|
|
name = "hoogle-local-0.1";
|
|
|
|
buildInputs = [hoogle rehoo];
|
|
|
|
|
2015-08-18 00:55:04 +01:00
|
|
|
phases = [ "buildPhase" ];
|
2015-01-22 23:10:08 +00:00
|
|
|
|
2015-08-18 00:55:04 +01:00
|
|
|
docPackages = (lib.closePropagation packages);
|
|
|
|
|
|
|
|
buildPhase = ''
|
2015-01-22 23:10:08 +00:00
|
|
|
if [ -z "$docPackages" ]; then
|
|
|
|
echo "ERROR: The packages attribute has not been set"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2015-08-18 00:55:04 +01:00
|
|
|
mkdir -p $out/share/doc/hoogle
|
2015-01-22 23:10:08 +00:00
|
|
|
|
|
|
|
function import_dbs() {
|
|
|
|
find $1 -name '*.txt' | while read f; do
|
|
|
|
newname=$(basename "$f" | tr '[:upper:]' '[:lower:]')
|
|
|
|
if [[ -f $f && ! -f ./$newname ]]; then
|
2015-08-18 00:55:04 +01:00
|
|
|
cp -p $f "./$newname"
|
2015-01-22 23:10:08 +00:00
|
|
|
hoogle convert -d "$(dirname $f)" "./$newname"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2015-08-18 00:55:04 +01:00
|
|
|
echo importing builtin packages
|
2016-02-01 04:00:43 +00:00
|
|
|
for docdir in ${ghc}/${docLibGlob}/*; do
|
2016-02-01 05:10:45 +00:00
|
|
|
name="$(basename $docdir)"
|
|
|
|
${opts isGhcjs ''docdir="$docdir/html"''}
|
2015-08-18 00:55:04 +01:00
|
|
|
if [[ -d $docdir ]]; then
|
|
|
|
import_dbs $docdir
|
2016-02-01 05:10:45 +00:00
|
|
|
ln -sfn $docdir $out/share/doc/hoogle/$name
|
2015-08-18 00:55:04 +01:00
|
|
|
fi
|
2015-01-22 23:10:08 +00:00
|
|
|
done
|
|
|
|
|
2015-08-18 00:55:04 +01:00
|
|
|
echo importing other packages
|
2015-01-22 23:10:08 +00:00
|
|
|
for i in $docPackages; do
|
|
|
|
if [[ ! $i == $out ]]; then
|
2016-02-01 04:00:43 +00:00
|
|
|
for docdir in $i/share/doc/*-${ghcName}-*/* $i/share/doc/*; do
|
2015-08-18 00:55:04 +01:00
|
|
|
name=`basename $docdir`
|
|
|
|
docdir=$docdir/html
|
2015-01-22 23:10:08 +00:00
|
|
|
if [[ -d $docdir ]]; then
|
|
|
|
import_dbs $docdir
|
2015-08-18 00:55:04 +01:00
|
|
|
ln -sfn $docdir $out/share/doc/hoogle/$name
|
2015-01-22 23:10:08 +00:00
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2015-08-18 00:55:04 +01:00
|
|
|
echo building hoogle database
|
|
|
|
# FIXME: rehoo is marked as depricated on Hackage
|
2015-01-22 23:10:08 +00:00
|
|
|
chmod 644 *.hoo *.txt
|
2015-09-02 15:24:06 +01:00
|
|
|
rehoo -j$NIX_BUILD_CORES -c64 .
|
2015-01-22 23:10:08 +00:00
|
|
|
|
2015-08-18 00:55:04 +01:00
|
|
|
mv default.hoo .x
|
|
|
|
rm -fr downloads *.dep *.txt *.hoo
|
|
|
|
mv .x $out/share/doc/hoogle/default.hoo
|
2015-01-22 23:10:08 +00:00
|
|
|
|
2015-08-18 00:55:04 +01:00
|
|
|
echo building haddock index
|
|
|
|
# adapted from GHC's gen_contents_index
|
|
|
|
cd $out/share/doc/hoogle
|
|
|
|
|
|
|
|
args=
|
|
|
|
for hdfile in `ls -1 */*.haddock | grep -v '/ghc\.haddock' | sort`
|
|
|
|
do
|
|
|
|
name_version=`echo "$hdfile" | sed 's#/.*##'`
|
|
|
|
args="$args --read-interface=$name_version,$hdfile"
|
|
|
|
done
|
|
|
|
|
2016-02-01 04:00:43 +00:00
|
|
|
${ghc}/bin/${haddockExe} --gen-index --gen-contents -o . \
|
2015-08-18 00:55:04 +01:00
|
|
|
-t "Haskell Hierarchical Libraries" \
|
2016-02-01 04:00:43 +00:00
|
|
|
-p ${prologue} \
|
2015-08-18 00:55:04 +01:00
|
|
|
$args
|
2015-01-22 23:10:08 +00:00
|
|
|
|
2015-08-18 00:55:04 +01:00
|
|
|
echo finishing up
|
2015-01-22 23:10:08 +00:00
|
|
|
mkdir -p $out/bin
|
|
|
|
substitute ${wrapper} $out/bin/hoogle \
|
|
|
|
--subst-var out --subst-var-by shell ${stdenv.shell} \
|
|
|
|
--subst-var-by hoogle ${hoogle}
|
|
|
|
chmod +x $out/bin/hoogle
|
|
|
|
'';
|
|
|
|
|
2015-08-17 20:45:13 +01:00
|
|
|
passthru = {
|
|
|
|
isHaskellLibrary = false; # for the filter in ./with-packages-wrapper.nix
|
|
|
|
};
|
|
|
|
|
2015-01-22 23:10:08 +00:00
|
|
|
meta = {
|
|
|
|
description = "A local Hoogle database";
|
|
|
|
platforms = ghc.meta.platforms;
|
|
|
|
hydraPlatforms = with stdenv.lib.platforms; none;
|
|
|
|
maintainers = with stdenv.lib.maintainers; [ ttuegel ];
|
|
|
|
};
|
|
|
|
}
|