Skip to content

Commit

Permalink
emacsPackages: squash elpa and nongnu update scripts
Browse files Browse the repository at this point in the history
They are practically identical. Let's merge them in a single script.

Now they can be called via `./update-package-sets <package sets>`.
  • Loading branch information
AndersonTorres committed Oct 26, 2024
1 parent 6745def commit 399dba1
Show file tree
Hide file tree
Showing 5 changed files with 50 additions and 24 deletions.
6 changes: 0 additions & 6 deletions pkgs/applications/editors/emacs/elisp-packages/update-elpa

This file was deleted.

This file was deleted.

6 changes: 0 additions & 6 deletions pkgs/applications/editors/emacs/elisp-packages/update-nongnu

This file was deleted.

This file was deleted.

50 changes: 50 additions & 0 deletions pkgs/applications/editors/emacs/elisp-packages/update-package-sets
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
#! /usr/bin/env nix-shell
#! nix-shell --show-trace ./emacs2nix.nix -i bash

usage(){
local PROGNAME="$1"

cat<<-EOF
Usage: update-package-sets args
args can be at least one from: elpa-devel, elpa, nongnu-devel, nongnu.
EOF
}

update_set(){
local PKGSET="$1"

local output="${PKGSET}-generated.nix"
local script="${PKGSET}-packages.sh"

eval "${script} --names ${EMACS2NIX}/names.nix -o ${output}"
nixfmt "${output}"
}

main(){
local SETS=( )

while (( $# )); do
case $1 in
"elpa-devel" | "elpa" | "nongnu-devel" | "nongnu")
# Do not include duplicates
if [[ ! ${SETS[@]} =~ $1 ]]; then
SETS+=( "$1" )
fi
shift
;;
*)
echo "Unknown package set: $1"
usage
exit 1
;;
esac
done

for SET in "${SETS[@]}"; do
echo "${SET}: updating..."
update_set "${SET}"
echo "${SET}: updated"
done
}

main "$@"

0 comments on commit 399dba1

Please sign in to comment.