forked from mirrors/nixpkgs
113 lines
2.9 KiB
Nix
113 lines
2.9 KiB
Nix
/*
|
|
|
|
# Updating
|
|
|
|
To update the list of packages from MELPA,
|
|
|
|
1. Run `./update-elpa`.
|
|
2. Check for evaluation errors:
|
|
env NIXPKGS_ALLOW_BROKEN=1 nix-instantiate ../../../../../ -A emacs.pkgs.elpaPackages
|
|
3. Run `git commit -m "elpa-packages $(date -Idate)" -- elpa-generated.nix`
|
|
|
|
## Update from overlay
|
|
|
|
Alternatively, run the following command:
|
|
|
|
./update-from-overlay
|
|
|
|
It will update both melpa and elpa packages using
|
|
https://github.com/nix-community/emacs-overlay. It's almost instantenous and
|
|
formats commits for you.
|
|
|
|
*/
|
|
|
|
{ lib, stdenv, texinfo, writeText, gcc, pkgs, buildPackages }:
|
|
|
|
self: let
|
|
|
|
markBroken = pkg: pkg.override {
|
|
elpaBuild = args: self.elpaBuild (args // {
|
|
meta = (args.meta or {}) // { broken = true; };
|
|
});
|
|
};
|
|
|
|
elpaBuild = import ../../../../build-support/emacs/elpa.nix {
|
|
inherit lib stdenv texinfo writeText gcc;
|
|
inherit (self) emacs;
|
|
};
|
|
|
|
# Use custom elpa url fetcher with fallback/uncompress
|
|
fetchurl = buildPackages.callPackage ./fetchelpa.nix { };
|
|
|
|
generateElpa = lib.makeOverridable ({
|
|
generated ? ./elpa-generated.nix
|
|
}: let
|
|
|
|
imported = import generated {
|
|
callPackage = pkgs: args: self.callPackage pkgs (args // {
|
|
inherit fetchurl;
|
|
});
|
|
};
|
|
|
|
super = removeAttrs imported [ "dash" ];
|
|
|
|
overrides = {
|
|
# upstream issue: Wrong type argument: arrayp, nil
|
|
org-transclusion =
|
|
if super.org-transclusion.version == "1.2.0"
|
|
then markBroken super.org-transclusion
|
|
else super.org-transclusion;
|
|
rcirc-menu = markBroken super.rcirc-menu; # Missing file header
|
|
cl-lib = null; # builtin
|
|
tle = null; # builtin
|
|
advice = null; # builtin
|
|
seq = if lib.versionAtLeast self.emacs.version "27"
|
|
then null
|
|
else super.seq;
|
|
project = if lib.versionAtLeast self.emacs.version "28"
|
|
then null
|
|
else super.project;
|
|
# Compilation instructions for the Ada executables:
|
|
# https://www.nongnu.org/ada-mode/ada-mode.html#Ada-executables
|
|
ada-mode = super.ada-mode.overrideAttrs (old: {
|
|
# actually unpack source of ada-mode and wisi
|
|
# which are both needed to compile the tools
|
|
# we need at runtime
|
|
dontUnpack = false;
|
|
srcs = [
|
|
super.ada-mode.src
|
|
self.wisi.src
|
|
];
|
|
|
|
sourceRoot = "ada-mode-${self.ada-mode.version}";
|
|
|
|
nativeBuildInputs = [
|
|
buildPackages.gnat
|
|
buildPackages.gprbuild
|
|
buildPackages.lzip
|
|
];
|
|
|
|
buildInputs = [
|
|
pkgs.gnatcoll-xref
|
|
];
|
|
|
|
preInstall = ''
|
|
./build.sh -j$NIX_BUILD_CORES
|
|
'';
|
|
|
|
postInstall = ''
|
|
./install.sh --prefix=$out
|
|
'';
|
|
|
|
meta = old.meta // {
|
|
maintainers = [ lib.maintainers.sternenseemann ];
|
|
};
|
|
});
|
|
};
|
|
|
|
elpaPackages = super // overrides;
|
|
|
|
in elpaPackages // { inherit elpaBuild; });
|
|
|
|
in generateElpa { }
|