Merge pull request #84663 from flokli/notmuch-multiple-output

notmuch: add separate `emacs` output
This commit is contained in:
Florian Klink 2020-04-08 13:31:52 +02:00 committed by GitHub
commit 68d37fe0c0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 14 additions and 4 deletions

View File

@ -215,7 +215,13 @@ environment.systemPackages = [
<itemizedlist>
<listitem>
<para />
<para>
The <package>notmuch</package> package move its emacs-related binaries and
emacs lisp files to a separate output. They're not part
of the default <literal>out<literal> output anymore - if you relied on the
<literal>notmuch-emacs-mua</literal> binary or the emacs lisp files, access them via
the <literal>notmuch.emacs</literal> output.
</para>
</listitem>
</itemizedlist>
</section>

View File

@ -3,7 +3,6 @@
, xapian, gmime, talloc, zlib
, doxygen, perl, texinfo
, pythonPackages
, bash-completion
, emacs
, ruby
, which, dtach, openssl, bash, gdb, man
@ -31,7 +30,6 @@ stdenv.mkDerivation rec {
doxygen # (optional) api docs
pythonPackages.sphinx # (optional) documentation -> doc/INSTALL
texinfo # (optional) documentation -> doc/INSTALL
bash-completion # (optional) dependency to install bash completion
] ++ optional withEmacs [ emacs ];
buildInputs = [
@ -56,8 +54,10 @@ stdenv.mkDerivation rec {
configureFlags = [
"--zshcompletiondir=${placeholder "out"}/share/zsh/site-functions"
"--bashcompletiondir=${placeholder "out"}/share/bash-completion/completions"
"--infodir=${placeholder "info"}"
] ++ optional (!withEmacs) "--without-emacs"
++ optional (withEmacs) "--emacslispdir=${placeholder "emacs"}/share/emacs/site-lisp"
++ optional (isNull ruby) "--without-ruby";
# Notmuch doesn't use autoconf and consequently doesn't tag --bindir and
@ -67,7 +67,7 @@ stdenv.mkDerivation rec {
makeFlags = [ "V=1" ];
outputs = [ "out" "man" "info" ];
outputs = [ "out" "man" "info" ] ++ stdenv.lib.optional withEmacs "emacs";
preCheck = let
test-database = fetchurl {
@ -86,6 +86,10 @@ stdenv.mkDerivation rec {
installTargets = [ "install" "install-man" "install-info" ];
postInstall = stdenv.lib.optionalString withEmacs ''
moveToOutput bin/notmuch-emacs-mua $emacs
'';
dontGzipMan = true; # already compressed
meta = {