2024-06-12 08:29:45 +00:00
|
|
|
#!/usr/bin/env nix-shell
|
|
|
|
#!nix-shell -i bash -p nix-update
|
|
|
|
|
2024-06-21 03:32:56 +00:00
|
|
|
NIX_FILES_TOP=/home/colin/nixos
|
|
|
|
|
2024-06-12 08:29:45 +00:00
|
|
|
usage() {
|
|
|
|
echo "update: update rev/hash for one or more packages"
|
2024-06-13 01:58:41 +00:00
|
|
|
echo "usage: update [options] [attr-path]"
|
|
|
|
echo ""
|
|
|
|
echo "options:"
|
|
|
|
echo "- --dry-run"
|
|
|
|
echo "- --verbose"
|
2024-06-12 08:29:45 +00:00
|
|
|
echo ""
|
|
|
|
echo "examples:"
|
2024-06-13 01:58:41 +00:00
|
|
|
echo "- update nixpkgs: update only the nixpkgs input"
|
|
|
|
echo "- update sane: update every package under the 'sane' attribute"
|
|
|
|
echo "- update: update everything i know how to update"
|
2024-06-12 08:44:02 +00:00
|
|
|
exit 1
|
2024-06-12 08:29:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
warn() {
|
|
|
|
echo "$@"
|
|
|
|
}
|
|
|
|
info() {
|
|
|
|
echo "$@"
|
|
|
|
}
|
2024-06-13 01:58:41 +00:00
|
|
|
debug() {
|
|
|
|
if [ -n "$verbose" ]; then
|
|
|
|
echo "$@"
|
|
|
|
fi
|
|
|
|
}
|
2024-06-12 08:29:45 +00:00
|
|
|
|
2024-06-12 08:44:02 +00:00
|
|
|
hasEffect() {
|
|
|
|
if [ -n "$dryRun" ]; then
|
|
|
|
echo "dry-run: skip $@"
|
|
|
|
else
|
|
|
|
eval "$@"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2024-06-12 08:29:45 +00:00
|
|
|
# usage: getPkgs outVar prefix
|
|
|
|
getPkgs() {
|
|
|
|
local -n attrsArr="$1"
|
|
|
|
local attrPrefix="$2"
|
|
|
|
if [ -z "$attrPrefix" ]; then
|
|
|
|
attrPrefix=sane
|
|
|
|
fi
|
|
|
|
|
2024-06-21 03:32:56 +00:00
|
|
|
# nix-env doesn't seem to build anything when evaluating queries,
|
|
|
|
# but since i use Import From Derivation along paths which i also want to query,
|
|
|
|
# then i need to ensure those derivations are available for import.
|
|
|
|
debug "creating requisite .drv store paths"
|
|
|
|
nix-instantiate -A nixpkgs "$NIX_FILES_TOP"
|
2024-06-20 22:54:16 +00:00
|
|
|
debug "querying attributes which match '$attrPrefix'"
|
2024-06-21 03:32:56 +00:00
|
|
|
local attrs=$(nix-env -f "$NIX_FILES_TOP" --query --available --attr-path --no-name -A "$attrPrefix" --show-trace)
|
2024-06-20 22:54:16 +00:00
|
|
|
debug "got: $attrs"
|
2024-06-12 08:44:02 +00:00
|
|
|
attrsArr+=($attrs)
|
2024-06-12 08:29:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
updateOnePkg() {
|
|
|
|
local attrPath="$1"
|
2024-06-14 09:47:00 +00:00
|
|
|
|
2024-06-21 03:32:56 +00:00
|
|
|
if [ -n "$ignore" ] && [[ "$attrPath" =~ ^"$ignore" ]]; then
|
2024-06-14 09:47:00 +00:00
|
|
|
warn "ignoring $attrPath"
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
|
2024-06-21 03:32:56 +00:00
|
|
|
local updateScript=$(nix eval --raw -f "$NIX_FILES_TOP" $attrPath.passthru.updateScript --apply 'builtins.concatStringsSep "'" "'"')
|
2024-06-12 08:29:45 +00:00
|
|
|
if [ -z "$updateScript" ]; then
|
|
|
|
warn "don't know how to update '$attrPath'"
|
|
|
|
return
|
|
|
|
fi
|
2024-06-13 01:58:41 +00:00
|
|
|
|
2024-06-21 03:32:56 +00:00
|
|
|
# make sure everything needed to invoke the update script exists in-store
|
|
|
|
local context=$(nix eval --raw -f "$NIX_FILES_TOP" $attrPath.passthru.updateScript --apply 's: builtins.concatStringsSep " " (builtins.foldl'"'"' (acc: next: acc ++ next) [] (builtins.map builtins.attrNames (builtins.map builtins.getContext s)))')
|
|
|
|
for c in $context; do
|
|
|
|
debug "realizing updateScript requisite: $context"
|
|
|
|
nix-store --realize "$c" || true
|
|
|
|
done
|
2024-06-13 01:58:41 +00:00
|
|
|
|
2024-06-21 03:32:56 +00:00
|
|
|
local UPDATE_NIX_NAME=$(nix eval --raw -f "$NIX_FILES_TOP" $attrPath.name)
|
|
|
|
local UPDATE_NIX_PNAME=$(nix eval --raw -f "$NIX_FILES_TOP" $attrPath.pname)
|
|
|
|
local UPDATE_NIX_OLD_VERSION=$(nix eval --raw -f "$NIX_FILES_TOP" $attrPath.version)
|
2024-06-12 08:29:45 +00:00
|
|
|
info "updating: '$attrPath'"
|
2024-06-13 01:58:41 +00:00
|
|
|
debug "$updateScript"
|
2024-06-21 03:32:56 +00:00
|
|
|
(
|
|
|
|
# update script assumes $PWD is an entry point to a writable copy of my nix config,
|
|
|
|
# so provide that:
|
|
|
|
pushd "$NIX_FILES_TOP/integrations/nix-update"
|
|
|
|
# we lose spaces inside the exec args... could `nix eval` without `--raw` to fix that.
|
|
|
|
UPDATE_NIX_NAME="$UPDATE_NIX_NAME" UPDATE_NIX_PNAME="$UPDATE_NIX_PNAME" UPDATE_NIX_OLD_VERSION="$UPDATE_NIX_OLD_VERSION" UPDATE_NIX_ATTR_PATH="$attrPath" eval $updateScript
|
|
|
|
popd
|
|
|
|
)
|
2024-06-12 08:29:45 +00:00
|
|
|
}
|
|
|
|
|
2024-06-12 08:44:02 +00:00
|
|
|
dryRun=
|
2024-06-14 09:47:00 +00:00
|
|
|
ignore=
|
2024-06-12 08:44:02 +00:00
|
|
|
toplevelsToUpdate=()
|
2024-06-13 01:58:41 +00:00
|
|
|
verbose=
|
2024-06-12 08:44:02 +00:00
|
|
|
parseArgs() {
|
|
|
|
while [ "$#" -ne 0 ]; do
|
|
|
|
local arg=$1
|
|
|
|
shift
|
|
|
|
case "$arg" in
|
|
|
|
(--help)
|
|
|
|
usage
|
|
|
|
;;
|
|
|
|
(--dry-run)
|
|
|
|
dryRun=1
|
|
|
|
;;
|
2024-06-13 01:58:41 +00:00
|
|
|
(--verbose)
|
|
|
|
verbose=1
|
|
|
|
;;
|
2024-06-12 08:44:02 +00:00
|
|
|
(*)
|
|
|
|
toplevelsToUpdate+=("$arg")
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
if [ "${#toplevelsToUpdate[@]}" -eq 0 ]; then
|
2024-06-14 09:47:00 +00:00
|
|
|
ignore=sane.feeds
|
2024-06-12 08:44:02 +00:00
|
|
|
toplevelsToUpdate=(sane)
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
parseArgs "$@"
|
2024-06-12 08:29:45 +00:00
|
|
|
pkgsToUpdate=()
|
2024-06-12 08:44:02 +00:00
|
|
|
for t in "${toplevelsToUpdate[@]}"; do
|
|
|
|
getPkgs pkgsToUpdate "$t"
|
|
|
|
done
|
2024-06-12 08:29:45 +00:00
|
|
|
|
|
|
|
for p in "${pkgsToUpdate[@]}"; do
|
2024-06-12 08:44:02 +00:00
|
|
|
hasEffect updateOnePkg "$p"
|
2024-06-12 08:29:45 +00:00
|
|
|
done
|