Merge pull request #41181 from matthewbauer/update/emacs26
emacs: 25.3 → 26.1
This commit is contained in:
commit
62b89d768f
136
pkgs/applications/editors/emacs/25.nix
Normal file
136
pkgs/applications/editors/emacs/25.nix
Normal file
@ -0,0 +1,136 @@
|
|||||||
|
{ stdenv, lib, fetchurl, ncurses, xlibsWrapper, libXaw, libXpm, Xaw3d
|
||||||
|
, pkgconfig, gettext, libXft, dbus, libpng, libjpeg, libungif
|
||||||
|
, libtiff, librsvg, gconf, libxml2, imagemagick, gnutls, libselinux
|
||||||
|
, alsaLib, cairo, acl, gpm, AppKit, CoreWLAN, Kerberos, GSS, ImageIO
|
||||||
|
, withX ? !stdenv.isDarwin
|
||||||
|
, withGTK2 ? false, gtk2 ? null
|
||||||
|
, withGTK3 ? true, gtk3 ? null, gsettings-desktop-schemas ? null
|
||||||
|
, withXwidgets ? false, webkitgtk24x-gtk3 ? null, wrapGAppsHook ? null, glib-networking ? null
|
||||||
|
, withCsrc ? true
|
||||||
|
, srcRepo ? false, autoconf ? null, automake ? null, texinfo ? null
|
||||||
|
}:
|
||||||
|
|
||||||
|
assert (libXft != null) -> libpng != null; # probably a bug
|
||||||
|
assert stdenv.isDarwin -> libXaw != null; # fails to link otherwise
|
||||||
|
assert withGTK2 -> withX || stdenv.isDarwin;
|
||||||
|
assert withGTK3 -> withX || stdenv.isDarwin;
|
||||||
|
assert withGTK2 -> !withGTK3 && gtk2 != null;
|
||||||
|
assert withGTK3 -> !withGTK2 && gtk3 != null;
|
||||||
|
assert withXwidgets -> withGTK3 && webkitgtk24x-gtk3 != null;
|
||||||
|
|
||||||
|
let
|
||||||
|
toolkit =
|
||||||
|
if withGTK2 then "gtk2"
|
||||||
|
else if withGTK3 then "gtk3"
|
||||||
|
else "lucid";
|
||||||
|
in
|
||||||
|
stdenv.mkDerivation rec {
|
||||||
|
name = "emacs-${version}${versionModifier}";
|
||||||
|
version = "25.3";
|
||||||
|
versionModifier = "";
|
||||||
|
|
||||||
|
src = fetchurl {
|
||||||
|
url = "mirror://gnu/emacs/${name}.tar.xz";
|
||||||
|
sha256 = "02y00y9q42g1iqgz5qhmsja75hwxd88yrn9zp14lanay0zkwafi5";
|
||||||
|
};
|
||||||
|
|
||||||
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
|
patches = lib.optionals stdenv.isDarwin [
|
||||||
|
./at-fdcwd.patch
|
||||||
|
|
||||||
|
# Backport of the fix to
|
||||||
|
# https://lists.gnu.org/archive/html/bug-gnu-emacs/2017-04/msg00201.html
|
||||||
|
# Should be removed when switching to Emacs 26.1
|
||||||
|
(fetchurl {
|
||||||
|
url = "https://gist.githubusercontent.com/aaronjensen/f45894ddf431ecbff78b1bcf533d3e6b/raw/6a5cd7f57341aba673234348d8b0d2e776f86719/Emacs-25-OS-X-use-vfork.patch";
|
||||||
|
sha256 = "1nlsxiaynswqhy99jf4mw9x0sndhwcrwy8713kq1l3xqv9dbrzgj";
|
||||||
|
})
|
||||||
|
];
|
||||||
|
|
||||||
|
nativeBuildInputs = [ pkgconfig ]
|
||||||
|
++ lib.optionals srcRepo [ autoconf automake texinfo ]
|
||||||
|
++ lib.optional (withX && (withGTK3 || withXwidgets)) wrapGAppsHook;
|
||||||
|
|
||||||
|
buildInputs =
|
||||||
|
[ ncurses gconf libxml2 gnutls alsaLib acl gpm gettext ]
|
||||||
|
++ lib.optionals stdenv.isLinux [ dbus libselinux ]
|
||||||
|
++ lib.optionals withX
|
||||||
|
[ xlibsWrapper libXaw Xaw3d libXpm libpng libjpeg libungif libtiff librsvg libXft
|
||||||
|
imagemagick gconf ]
|
||||||
|
++ lib.optional (withX && withGTK2) gtk2
|
||||||
|
++ lib.optionals (withX && withGTK3) [ gtk3 gsettings-desktop-schemas ]
|
||||||
|
++ lib.optional (stdenv.isDarwin && withX) cairo
|
||||||
|
++ lib.optionals (withX && withXwidgets) [ webkitgtk24x-gtk3 glib-networking ];
|
||||||
|
|
||||||
|
propagatedBuildInputs = lib.optionals stdenv.isDarwin [ AppKit GSS ImageIO ];
|
||||||
|
|
||||||
|
hardeningDisable = [ "format" ];
|
||||||
|
|
||||||
|
configureFlags = [ "--with-modules" ] ++
|
||||||
|
(if stdenv.isDarwin
|
||||||
|
then [ "--with-ns" "--disable-ns-self-contained" ]
|
||||||
|
else if withX
|
||||||
|
then [ "--with-x-toolkit=${toolkit}" "--with-xft" ]
|
||||||
|
else [ "--with-x=no" "--with-xpm=no" "--with-jpeg=no" "--with-png=no"
|
||||||
|
"--with-gif=no" "--with-tiff=no" ])
|
||||||
|
++ lib.optional withXwidgets "--with-xwidgets";
|
||||||
|
|
||||||
|
preConfigure = lib.optionalString srcRepo ''
|
||||||
|
./autogen.sh
|
||||||
|
'' + ''
|
||||||
|
substituteInPlace lisp/international/mule-cmds.el \
|
||||||
|
--replace /usr/share/locale ${gettext}/share/locale
|
||||||
|
|
||||||
|
for makefile_in in $(find . -name Makefile.in -print); do
|
||||||
|
substituteInPlace $makefile_in --replace /bin/pwd pwd
|
||||||
|
done
|
||||||
|
'';
|
||||||
|
|
||||||
|
installTargets = "tags install";
|
||||||
|
|
||||||
|
postInstall = ''
|
||||||
|
mkdir -p $out/share/emacs/site-lisp
|
||||||
|
cp ${./site-start.el} $out/share/emacs/site-lisp/site-start.el
|
||||||
|
$out/bin/emacs --batch -f batch-byte-compile $out/share/emacs/site-lisp/site-start.el
|
||||||
|
|
||||||
|
rm -rf $out/var
|
||||||
|
rm -rf $out/share/emacs/${version}/site-lisp
|
||||||
|
'' + lib.optionalString withCsrc ''
|
||||||
|
for srcdir in src lisp lwlib ; do
|
||||||
|
dstdir=$out/share/emacs/${version}/$srcdir
|
||||||
|
mkdir -p $dstdir
|
||||||
|
find $srcdir -name "*.[chm]" -exec cp {} $dstdir \;
|
||||||
|
cp $srcdir/TAGS $dstdir
|
||||||
|
echo '((nil . ((tags-file-name . "TAGS"))))' > $dstdir/.dir-locals.el
|
||||||
|
done
|
||||||
|
'' + lib.optionalString stdenv.isDarwin ''
|
||||||
|
mkdir -p $out/Applications
|
||||||
|
mv nextstep/Emacs.app $out/Applications
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = with stdenv.lib; {
|
||||||
|
description = "The extensible, customizable GNU text editor";
|
||||||
|
homepage = http://www.gnu.org/software/emacs/;
|
||||||
|
license = licenses.gpl3Plus;
|
||||||
|
maintainers = with maintainers; [ chaoflow lovek323 peti the-kenny jwiegley ];
|
||||||
|
platforms = platforms.all;
|
||||||
|
|
||||||
|
longDescription = ''
|
||||||
|
GNU Emacs is an extensible, customizable text editor—and more. At its
|
||||||
|
core is an interpreter for Emacs Lisp, a dialect of the Lisp
|
||||||
|
programming language with extensions to support text editing.
|
||||||
|
|
||||||
|
The features of GNU Emacs include: content-sensitive editing modes,
|
||||||
|
including syntax coloring, for a wide variety of file types including
|
||||||
|
plain text, source code, and HTML; complete built-in documentation,
|
||||||
|
including a tutorial for new users; full Unicode support for nearly all
|
||||||
|
human languages and their scripts; highly customizable, using Emacs
|
||||||
|
Lisp code or a graphical interface; a large number of extensions that
|
||||||
|
add other functionality, including a project planner, mail and news
|
||||||
|
reader, debugger interface, calendar, and more. Many of these
|
||||||
|
extensions are distributed with GNU Emacs; others are available
|
||||||
|
separately.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
@ -8,8 +8,8 @@ diff -ru -x '*~' emacs-25.3/src/Makefile.in emacs-25.3-new/src/Makefile.in
|
|||||||
ifeq ($(CANNOT_DUMP),yes)
|
ifeq ($(CANNOT_DUMP),yes)
|
||||||
ln -f temacs$(EXEEXT) $@
|
ln -f temacs$(EXEEXT) $@
|
||||||
else
|
else
|
||||||
- LC_ALL=C $(RUN_TEMACS) -batch -l loadup dump
|
- LC_ALL=C $(RUN_TEMACS) -batch $(BUILD_DETAILS) -l loadup dump
|
||||||
+ env -i LC_ALL=C $(RUN_TEMACS) -batch -l loadup dump
|
+ env -i LC_ALL=C $(RUN_TEMACS) -batch $(BUILD_DETAILS) -l loadup dump
|
||||||
ifneq ($(PAXCTL_dumped),)
|
ifneq ($(PAXCTL_dumped),)
|
||||||
$(PAXCTL_dumped) $@
|
$(PAXCTL_dumped) $@
|
||||||
endif
|
endif
|
||||||
|
@ -26,30 +26,26 @@ let
|
|||||||
in
|
in
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
name = "emacs-${version}${versionModifier}";
|
name = "emacs-${version}${versionModifier}";
|
||||||
version = "25.3";
|
version = "26.1";
|
||||||
versionModifier = "";
|
versionModifier = "";
|
||||||
|
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "mirror://gnu/emacs/${name}.tar.xz";
|
url = "mirror://gnu/emacs/${name}.tar.xz";
|
||||||
sha256 = "02y00y9q42g1iqgz5qhmsja75hwxd88yrn9zp14lanay0zkwafi5";
|
sha256 = "0b6k1wq44rc8gkvxhi1bbjxbz3cwg29qbq8mklq2az6p1hjgrx0w";
|
||||||
};
|
};
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
enableParallelBuilding = true;
|
||||||
|
|
||||||
patches = [
|
patches = [
|
||||||
./clean-env.patch
|
./clean-env.patch
|
||||||
] ++ lib.optionals stdenv.isDarwin [
|
|
||||||
./at-fdcwd.patch
|
|
||||||
|
|
||||||
# Backport of the fix to
|
|
||||||
# https://lists.gnu.org/archive/html/bug-gnu-emacs/2017-04/msg00201.html
|
|
||||||
# Should be removed when switching to Emacs 26.1
|
|
||||||
(fetchurl {
|
|
||||||
url = "https://gist.githubusercontent.com/aaronjensen/f45894ddf431ecbff78b1bcf533d3e6b/raw/6a5cd7f57341aba673234348d8b0d2e776f86719/Emacs-25-OS-X-use-vfork.patch";
|
|
||||||
sha256 = "1nlsxiaynswqhy99jf4mw9x0sndhwcrwy8713kq1l3xqv9dbrzgj";
|
|
||||||
})
|
|
||||||
];
|
];
|
||||||
|
|
||||||
|
postPatch = lib.optionalString srcRepo ''
|
||||||
|
rm -fr .git
|
||||||
|
'';
|
||||||
|
|
||||||
|
CFLAGS = "-DMAC_OS_X_VERSION_MAX_ALLOWED=101200";
|
||||||
|
|
||||||
nativeBuildInputs = [ pkgconfig ]
|
nativeBuildInputs = [ pkgconfig ]
|
||||||
++ lib.optionals srcRepo [ autoconf automake texinfo ]
|
++ lib.optionals srcRepo [ autoconf automake texinfo ]
|
||||||
++ lib.optional (withX && (withGTK3 || withXwidgets)) wrapGAppsHook;
|
++ lib.optional (withX && (withGTK3 || withXwidgets)) wrapGAppsHook;
|
||||||
|
@ -78,6 +78,7 @@ mapAliases (rec {
|
|||||||
double_conversion = double-conversion; # 2017-11-22
|
double_conversion = double-conversion; # 2017-11-22
|
||||||
dwarf_fortress = dwarf-fortress; # added 2016-01-23
|
dwarf_fortress = dwarf-fortress; # added 2016-01-23
|
||||||
emacs25Macport_25_1 = emacs25Macport; # added 2018-04-25
|
emacs25Macport_25_1 = emacs25Macport; # added 2018-04-25
|
||||||
|
emacsMelpa = emacs25PackagesNg; # for backward compatibility
|
||||||
enblendenfuse = enblend-enfuse; # 2015-09-30
|
enblendenfuse = enblend-enfuse; # 2015-09-30
|
||||||
evolution_data_server = evolution-data-server; # added 2018-02-25
|
evolution_data_server = evolution-data-server; # added 2018-02-25
|
||||||
etcdctl = etcd; # added 2018-04-25
|
etcdctl = etcd; # added 2018-04-25
|
||||||
|
@ -15382,12 +15382,29 @@ with pkgs;
|
|||||||
|
|
||||||
elvis = callPackage ../applications/editors/elvis { };
|
elvis = callPackage ../applications/editors/elvis { };
|
||||||
|
|
||||||
emacs = emacs25;
|
emacs = emacs26;
|
||||||
emacsPackages = emacs25Packages;
|
emacsPackages = emacs26Packages;
|
||||||
emacsPackagesNg = emacs25PackagesNg;
|
emacsPackagesNg = emacs26PackagesNg;
|
||||||
emacsMelpa = emacs25PackagesNg; # for backward compatibility
|
|
||||||
|
|
||||||
emacs25 = callPackage ../applications/editors/emacs {
|
emacs26 = callPackage ../applications/editors/emacs {
|
||||||
|
# use override to enable additional features
|
||||||
|
libXaw = xorg.libXaw;
|
||||||
|
Xaw3d = null;
|
||||||
|
gconf = null;
|
||||||
|
alsaLib = null;
|
||||||
|
imagemagick = null;
|
||||||
|
acl = null;
|
||||||
|
gpm = null;
|
||||||
|
inherit (darwin.apple_sdk.frameworks) AppKit CoreWLAN GSS Kerberos ImageIO;
|
||||||
|
};
|
||||||
|
|
||||||
|
emacs26-nox = lowPrio (appendToName "nox" (emacs26.override {
|
||||||
|
withX = false;
|
||||||
|
withGTK2 = false;
|
||||||
|
withGTK3 = false;
|
||||||
|
}));
|
||||||
|
|
||||||
|
emacs25 = callPackage ../applications/editors/emacs/25.nix {
|
||||||
# use override to enable additional features
|
# use override to enable additional features
|
||||||
libXaw = xorg.libXaw;
|
libXaw = xorg.libXaw;
|
||||||
Xaw3d = null;
|
Xaw3d = null;
|
||||||
@ -15556,6 +15573,7 @@ with pkgs;
|
|||||||
};
|
};
|
||||||
|
|
||||||
emacs25Packages = emacsPackagesGen emacs25 pkgs.emacs25Packages;
|
emacs25Packages = emacsPackagesGen emacs25 pkgs.emacs25Packages;
|
||||||
|
emacs26Packages = emacsPackagesGen emacs26 pkgs.emacs26Packages;
|
||||||
|
|
||||||
emacsPackagesNgGen = emacs: import ./emacs-packages.nix {
|
emacsPackagesNgGen = emacs: import ./emacs-packages.nix {
|
||||||
inherit lib newScope stdenv;
|
inherit lib newScope stdenv;
|
||||||
@ -15579,8 +15597,9 @@ with pkgs;
|
|||||||
};
|
};
|
||||||
|
|
||||||
emacs25PackagesNg = emacsPackagesNgGen emacs25;
|
emacs25PackagesNg = emacsPackagesNgGen emacs25;
|
||||||
|
|
||||||
emacs25WithPackages = emacs25PackagesNg.emacsWithPackages;
|
emacs25WithPackages = emacs25PackagesNg.emacsWithPackages;
|
||||||
|
emacs26PackagesNg = emacsPackagesNgGen emacs26;
|
||||||
|
emacs26WithPackages = emacs26PackagesNg.emacsWithPackages;
|
||||||
emacsWithPackages = emacsPackagesNg.emacsWithPackages;
|
emacsWithPackages = emacsPackagesNg.emacsWithPackages;
|
||||||
|
|
||||||
inherit (gnome3) empathy;
|
inherit (gnome3) empathy;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user