mirror of
https://github.com/nix-community/home-manager
synced 2025-01-26 02:45:01 +01:00
treewide: deprecate DRY_RUN_CMD
and DRY_RUN_NULL
As a replacement, this adds the `run` helper function.
This commit is contained in:
parent
78ece60890
commit
a04f37fab0
25 changed files with 125 additions and 67 deletions
|
@ -31,6 +31,35 @@ This release has the following notable changes:
|
||||||
_all_ Home Manager state from your user environment. This includes
|
_all_ Home Manager state from your user environment. This includes
|
||||||
removing all your historic Home Manager generations!
|
removing all your historic Home Manager generations!
|
||||||
|
|
||||||
|
- The use of `$DRY_RUN_CMD` and `$DRY_RUN_NULL` in activation script
|
||||||
|
blocks is now deprecated. Instead use the new shell function
|
||||||
|
{command}`run`. In most cases it is sufficient to replace
|
||||||
|
`$DRY_RUN_CMD` by {command}`run`. For example, if your configuration
|
||||||
|
currently contains
|
||||||
|
|
||||||
|
```nix
|
||||||
|
home.activation.reportChanges = config.lib.dag.entryAnywhere ''
|
||||||
|
if [[ -v oldGenPath ]]; then
|
||||||
|
$DRY_RUN_CMD nix store diff-closures $oldGenPath $newGenPath
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
```
|
||||||
|
|
||||||
|
then you are now encouraged to change to
|
||||||
|
|
||||||
|
```nix
|
||||||
|
home.activation.reportChanges = config.lib.dag.entryAnywhere ''
|
||||||
|
if [[ -v oldGenPath ]]; then
|
||||||
|
run nix store diff-closures $oldGenPath $newGenPath
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
```
|
||||||
|
|
||||||
|
See the description of [home.activation](#opt-home.activation) for
|
||||||
|
more. The deprecated variables will continue to work for now but
|
||||||
|
their use may in the future trigger a warning message and eventually
|
||||||
|
they may be removed entirely.
|
||||||
|
|
||||||
## State Version Changes {#sec-release-24.05-state-version-changes}
|
## State Version Changes {#sec-release-24.05-state-version-changes}
|
||||||
|
|
||||||
The state version in this release includes the changes below. These
|
The state version in this release includes the changes below. These
|
||||||
|
|
|
@ -21,18 +21,12 @@ function setNixProfileCommands() {
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
function setVerboseAndDryRun() {
|
function setVerboseArg() {
|
||||||
if [[ -v VERBOSE ]]; then
|
if [[ -v VERBOSE ]]; then
|
||||||
export VERBOSE_ARG="--verbose"
|
export VERBOSE_ARG="--verbose"
|
||||||
else
|
else
|
||||||
export VERBOSE_ARG=""
|
export VERBOSE_ARG=""
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -v DRY_RUN ]] ; then
|
|
||||||
export DRY_RUN_CMD=echo
|
|
||||||
else
|
|
||||||
export DRY_RUN_CMD=""
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function setWorkDir() {
|
function setWorkDir() {
|
||||||
|
@ -661,7 +655,7 @@ function doListGens() {
|
||||||
# generations to remove.
|
# generations to remove.
|
||||||
function doRmGenerations() {
|
function doRmGenerations() {
|
||||||
setHomeManagerPathVariables
|
setHomeManagerPathVariables
|
||||||
setVerboseAndDryRun
|
setVerboseArg
|
||||||
|
|
||||||
pushd "$HM_PROFILE_DIR" > /dev/null
|
pushd "$HM_PROFILE_DIR" > /dev/null
|
||||||
|
|
||||||
|
@ -674,7 +668,7 @@ function doRmGenerations() {
|
||||||
_i 'Cannot remove the current generation %s' "$generationId" >&2
|
_i 'Cannot remove the current generation %s' "$generationId" >&2
|
||||||
else
|
else
|
||||||
_i 'Removing generation %s' "$generationId"
|
_i 'Removing generation %s' "$generationId"
|
||||||
$DRY_RUN_CMD rm $VERBOSE_ARG $linkName
|
run rm $VERBOSE_ARG $linkName
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
|
@ -809,7 +803,6 @@ function doShowNews() {
|
||||||
|
|
||||||
function doUninstall() {
|
function doUninstall() {
|
||||||
setHomeManagerPathVariables
|
setHomeManagerPathVariables
|
||||||
setVerboseAndDryRun
|
|
||||||
setNixProfileCommands
|
setNixProfileCommands
|
||||||
|
|
||||||
_i 'This will remove Home Manager from your system.'
|
_i 'This will remove Home Manager from your system.'
|
||||||
|
|
|
@ -83,3 +83,27 @@ function _iNote() {
|
||||||
_i "$@"
|
_i "$@"
|
||||||
echo -n "${normalColor}"
|
echo -n "${normalColor}"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Runs the given command on live run, otherwise prints the command to standard
|
||||||
|
# output.
|
||||||
|
#
|
||||||
|
# If given the command line option `--silence`, then the command's standard and
|
||||||
|
# error output is sent to `/dev/null` on a live run.
|
||||||
|
#
|
||||||
|
# Note, the run function is exported. I.e., it is available also to called Bash
|
||||||
|
# script.
|
||||||
|
function run() {
|
||||||
|
if [[ $1 == '--silence' ]]; then
|
||||||
|
local silence=1
|
||||||
|
shift
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -v DRY_RUN ]] ; then
|
||||||
|
echo "$@"
|
||||||
|
elif [[ -v silence ]] ; then
|
||||||
|
"$@" > /dev/null 2>&1
|
||||||
|
else
|
||||||
|
"$@"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
export -f run
|
||||||
|
|
|
@ -169,6 +169,8 @@ in
|
||||||
home.activation.linkGeneration = hm.dag.entryAfter ["writeBoundary"] (
|
home.activation.linkGeneration = hm.dag.entryAfter ["writeBoundary"] (
|
||||||
let
|
let
|
||||||
link = pkgs.writeShellScript "link" ''
|
link = pkgs.writeShellScript "link" ''
|
||||||
|
${config.lib.bash.initHomeManagerLib}
|
||||||
|
|
||||||
newGenFiles="$1"
|
newGenFiles="$1"
|
||||||
shift
|
shift
|
||||||
for sourcePath in "$@" ; do
|
for sourcePath in "$@" ; do
|
||||||
|
@ -177,7 +179,7 @@ in
|
||||||
if [[ -e "$targetPath" && ! -L "$targetPath" && -n "$HOME_MANAGER_BACKUP_EXT" ]] ; then
|
if [[ -e "$targetPath" && ! -L "$targetPath" && -n "$HOME_MANAGER_BACKUP_EXT" ]] ; then
|
||||||
# The target exists, back it up
|
# The target exists, back it up
|
||||||
backup="$targetPath.$HOME_MANAGER_BACKUP_EXT"
|
backup="$targetPath.$HOME_MANAGER_BACKUP_EXT"
|
||||||
$DRY_RUN_CMD mv $VERBOSE_ARG "$targetPath" "$backup" || errorEcho "Moving '$targetPath' failed!"
|
run mv $VERBOSE_ARG "$targetPath" "$backup" || errorEcho "Moving '$targetPath' failed!"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -e "$targetPath" && ! -L "$targetPath" ]] && cmp -s "$sourcePath" "$targetPath" ; then
|
if [[ -e "$targetPath" && ! -L "$targetPath" ]] && cmp -s "$sourcePath" "$targetPath" ; then
|
||||||
|
@ -186,8 +188,8 @@ in
|
||||||
else
|
else
|
||||||
# Place that symlink, --force
|
# Place that symlink, --force
|
||||||
# This can still fail if the target is a directory, in which case we bail out.
|
# This can still fail if the target is a directory, in which case we bail out.
|
||||||
$DRY_RUN_CMD mkdir -p $VERBOSE_ARG "$(dirname "$targetPath")"
|
run mkdir -p $VERBOSE_ARG "$(dirname "$targetPath")"
|
||||||
$DRY_RUN_CMD ln -Tsf $VERBOSE_ARG "$sourcePath" "$targetPath" || exit 1
|
run ln -Tsf $VERBOSE_ARG "$sourcePath" "$targetPath" || exit 1
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
'';
|
'';
|
||||||
|
@ -209,7 +211,7 @@ in
|
||||||
warnEcho "Path '$targetPath' does not link into a Home Manager generation. Skipping delete."
|
warnEcho "Path '$targetPath' does not link into a Home Manager generation. Skipping delete."
|
||||||
else
|
else
|
||||||
$VERBOSE_ECHO "Checking $targetPath: gone (deleting)"
|
$VERBOSE_ECHO "Checking $targetPath: gone (deleting)"
|
||||||
$DRY_RUN_CMD rm $VERBOSE_ARG "$targetPath"
|
run rm $VERBOSE_ARG "$targetPath"
|
||||||
|
|
||||||
# Recursively delete empty parent directories.
|
# Recursively delete empty parent directories.
|
||||||
targetDir="$(dirname "$relativePath")"
|
targetDir="$(dirname "$relativePath")"
|
||||||
|
@ -219,7 +221,7 @@ in
|
||||||
# Call rmdir with a relative path excluding $HOME.
|
# Call rmdir with a relative path excluding $HOME.
|
||||||
# Otherwise, it might try to delete $HOME and exit
|
# Otherwise, it might try to delete $HOME and exit
|
||||||
# with a permission error.
|
# with a permission error.
|
||||||
$DRY_RUN_CMD rmdir $VERBOSE_ARG \
|
run rmdir $VERBOSE_ARG \
|
||||||
-p --ignore-fail-on-non-empty \
|
-p --ignore-fail-on-non-empty \
|
||||||
"$targetDir"
|
"$targetDir"
|
||||||
|
|
||||||
|
@ -267,14 +269,14 @@ in
|
||||||
nix profile list --profile "$genProfilePath" \
|
nix profile list --profile "$genProfilePath" \
|
||||||
| cut -d ' ' -f 4 \
|
| cut -d ' ' -f 4 \
|
||||||
| xargs -t $DRY_RUN_CMD nix profile remove $VERBOSE_ARG --profile "$genProfilePath"
|
| xargs -t $DRY_RUN_CMD nix profile remove $VERBOSE_ARG --profile "$genProfilePath"
|
||||||
$DRY_RUN_CMD nix profile install $VERBOSE_ARG --profile "$genProfilePath" "$newGenPath"
|
run nix profile install $VERBOSE_ARG --profile "$genProfilePath" "$newGenPath"
|
||||||
else
|
else
|
||||||
$DRY_RUN_CMD nix-env $VERBOSE_ARG --profile "$genProfilePath" --set "$newGenPath"
|
run nix-env $VERBOSE_ARG --profile "$genProfilePath" --set "$newGenPath"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
$DRY_RUN_CMD nix-store --realise "$newGenPath" --add-root "$newGenGcPath" > "$DRY_RUN_NULL"
|
run --silence nix-store --realise "$newGenPath" --add-root "$newGenGcPath"
|
||||||
if [[ -e "$legacyGenGcPath" ]]; then
|
if [[ -e "$legacyGenGcPath" ]]; then
|
||||||
$DRY_RUN_CMD rm $VERBOSE_ARG "$legacyGenGcPath"
|
run rm $VERBOSE_ARG "$legacyGenGcPath"
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
_i "No change so reusing latest profile generation %s" "$oldGenNum"
|
_i "No change so reusing latest profile generation %s" "$oldGenNum"
|
||||||
|
|
|
@ -374,7 +374,7 @@ in
|
||||||
example = literalExpression ''
|
example = literalExpression ''
|
||||||
{
|
{
|
||||||
myActivationAction = lib.hm.dag.entryAfter ["writeBoundary"] '''
|
myActivationAction = lib.hm.dag.entryAfter ["writeBoundary"] '''
|
||||||
$DRY_RUN_CMD ln -s $VERBOSE_ARG \
|
run ln -s $VERBOSE_ARG \
|
||||||
''${builtins.toPath ./link-me-directly} $HOME
|
''${builtins.toPath ./link-me-directly} $HOME
|
||||||
''';
|
''';
|
||||||
}
|
}
|
||||||
|
@ -396,11 +396,19 @@ in
|
||||||
collisions between non-managed files and files defined in
|
collisions between non-managed files and files defined in
|
||||||
[](#opt-home.file).
|
[](#opt-home.file).
|
||||||
|
|
||||||
A script block should respect the {var}`DRY_RUN`
|
A script block should respect the {var}`DRY_RUN` variable. If it is set
|
||||||
variable, if it is set then the actions taken by the script
|
then the actions taken by the script should be logged to standard out
|
||||||
should be logged to standard out and not actually performed.
|
and not actually performed. A convenient shell function {command}`run`
|
||||||
The variable {var}`DRY_RUN_CMD` is set to
|
is provided for activation script blocks. It is used as follows:
|
||||||
{command}`echo` if dry run is enabled.
|
|
||||||
|
{command}`run {command}`
|
||||||
|
: Runs the given command on live run, otherwise prints the command to
|
||||||
|
standard output.
|
||||||
|
|
||||||
|
{command}`run --silence {command}`
|
||||||
|
: Runs the given command on live run and sends its standard and error
|
||||||
|
output to {file}`/dev/null`, otherwise prints the command to standard
|
||||||
|
output.
|
||||||
|
|
||||||
A script block should also respect the
|
A script block should also respect the
|
||||||
{var}`VERBOSE` variable, and if set print
|
{var}`VERBOSE` variable, and if set print
|
||||||
|
@ -594,7 +602,7 @@ in
|
||||||
|
|
||||||
nixProfileRemove 'home-manager-path'
|
nixProfileRemove 'home-manager-path'
|
||||||
|
|
||||||
$DRY_RUN_CMD $oldNix profile install $1
|
run $oldNix profile install $1
|
||||||
}
|
}
|
||||||
|
|
||||||
if [[ -e ${cfg.profileDirectory}/manifest.json ]] ; then
|
if [[ -e ${cfg.profileDirectory}/manifest.json ]] ; then
|
||||||
|
@ -604,7 +612,7 @@ in
|
||||||
REMOVE_CMD_SYNTAX='nix profile remove {number | store path}'
|
REMOVE_CMD_SYNTAX='nix profile remove {number | store path}'
|
||||||
else
|
else
|
||||||
INSTALL_CMD="nix-env -i"
|
INSTALL_CMD="nix-env -i"
|
||||||
INSTALL_CMD_ACTUAL="$DRY_RUN_CMD nix-env -i"
|
INSTALL_CMD_ACTUAL="run nix-env -i"
|
||||||
LIST_CMD="nix-env -q"
|
LIST_CMD="nix-env -q"
|
||||||
REMOVE_CMD_SYNTAX='nix-env -e {package name}'
|
REMOVE_CMD_SYNTAX='nix-env -e {package name}'
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -162,7 +162,7 @@ in {
|
||||||
fi
|
fi
|
||||||
if [[ -f "$dstPath" ]]; then
|
if [[ -f "$dstPath" ]]; then
|
||||||
for (( i = 0; i < bootout_retries; i++ )); do
|
for (( i = 0; i < bootout_retries; i++ )); do
|
||||||
$DRY_RUN_CMD /bin/launchctl bootout "$domain/$agentName" || err=$?
|
run /bin/launchctl bootout "$domain/$agentName" || err=$?
|
||||||
if [[ -v DRY_RUN ]]; then
|
if [[ -v DRY_RUN ]]; then
|
||||||
break
|
break
|
||||||
fi
|
fi
|
||||||
|
@ -177,8 +177,8 @@ in {
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
$DRY_RUN_CMD install -Dm444 -T "$srcPath" "$dstPath"
|
run install -Dm444 -T "$srcPath" "$dstPath"
|
||||||
$DRY_RUN_CMD /bin/launchctl bootstrap "$domain" "$dstPath"
|
run /bin/launchctl bootstrap "$domain" "$dstPath"
|
||||||
done
|
done
|
||||||
|
|
||||||
if [[ ! -e "$oldDir" ]]; then
|
if [[ ! -e "$oldDir" ]]; then
|
||||||
|
@ -194,7 +194,7 @@ in {
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
|
|
||||||
$DRY_RUN_CMD /bin/launchctl bootout "$domain/$agentName" || :
|
run /bin/launchctl bootout "$domain/$agentName" || :
|
||||||
if [[ ! -e "$dstPath" ]]; then
|
if [[ ! -e "$dstPath" ]]; then
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
|
@ -202,7 +202,7 @@ in {
|
||||||
warnEcho "Skipping deletion of '$dstPath', since its contents have diverged"
|
warnEcho "Skipping deletion of '$dstPath', since its contents have diverged"
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
$DRY_RUN_CMD rm -f $VERBOSE_ARG "$dstPath"
|
run rm -f $VERBOSE_ARG "$dstPath"
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -115,7 +115,7 @@ function nixProfileRemove() {
|
||||||
nixProfileList "$1" | xargs -t $DRY_RUN_CMD nix profile remove $VERBOSE_ARG
|
nixProfileList "$1" | xargs -t $DRY_RUN_CMD nix profile remove $VERBOSE_ARG
|
||||||
else
|
else
|
||||||
if nix-env -q | grep -q "^$1$"; then
|
if nix-env -q | grep -q "^$1$"; then
|
||||||
$DRY_RUN_CMD nix-env -e "$1" > $DRY_RUN_NULL 2>&1
|
run --silence nix-env -e "$1"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
@ -161,6 +161,9 @@ nix-env -q > /dev/null 2>&1 || true
|
||||||
migrateProfile
|
migrateProfile
|
||||||
setupVars
|
setupVars
|
||||||
|
|
||||||
|
# Note, the DRY_RUN_CMD and DRY_RUN_NULL variables are deprecated and should not
|
||||||
|
# be used inside the Home Manager project. They are provided here for backwards
|
||||||
|
# compatibility.
|
||||||
if [[ -v DRY_RUN ]] ; then
|
if [[ -v DRY_RUN ]] ; then
|
||||||
_i "This is a dry run"
|
_i "This is a dry run"
|
||||||
export DRY_RUN_CMD=echo
|
export DRY_RUN_CMD=echo
|
||||||
|
|
|
@ -112,7 +112,7 @@ in {
|
||||||
'($old[] - $new[])[]' \
|
'($old[] - $new[])[]' \
|
||||||
| while read -r key; do
|
| while read -r key; do
|
||||||
$VERBOSE_ECHO "Resetting dconf key \"$key\""
|
$VERBOSE_ECHO "Resetting dconf key \"$key\""
|
||||||
$DRY_RUN_CMD $DCONF_DBUS_RUN_SESSION dconf reset "$key"
|
run $DCONF_DBUS_RUN_SESSION dconf reset "$key"
|
||||||
done
|
done
|
||||||
'';
|
'';
|
||||||
in ''
|
in ''
|
||||||
|
@ -128,7 +128,7 @@ in {
|
||||||
"$newGenPath/${statePath}"
|
"$newGenPath/${statePath}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
$DRY_RUN_CMD $DCONF_DBUS_RUN_SESSION ${pkgs.dconf}/bin/dconf load / < ${iniFile}
|
run $DCONF_DBUS_RUN_SESSION ${pkgs.dconf}/bin/dconf load / < ${iniFile}
|
||||||
|
|
||||||
unset DCONF_DBUS_RUN_SESSION
|
unset DCONF_DBUS_RUN_SESSION
|
||||||
'');
|
'');
|
||||||
|
|
|
@ -31,19 +31,19 @@ in {
|
||||||
nixProfileRemove home-manager-path
|
nixProfileRemove home-manager-path
|
||||||
|
|
||||||
if [[ -e $hmDataPath ]]; then
|
if [[ -e $hmDataPath ]]; then
|
||||||
$DRY_RUN_CMD rm $VERBOSE_ARG -r "$hmDataPath"
|
run rm $VERBOSE_ARG -r "$hmDataPath"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -e $hmStatePath ]]; then
|
if [[ -e $hmStatePath ]]; then
|
||||||
$DRY_RUN_CMD rm $VERBOSE_ARG -r "$hmStatePath"
|
run rm $VERBOSE_ARG -r "$hmStatePath"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -e $genProfilePath ]]; then
|
if [[ -e $genProfilePath ]]; then
|
||||||
$DRY_RUN_CMD rm $VERBOSE_ARG "$genProfilePath"*
|
run rm $VERBOSE_ARG "$genProfilePath"*
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ -e $legacyGenGcPath ]]; then
|
if [[ -e $legacyGenGcPath ]]; then
|
||||||
$DRY_RUN_CMD rm $VERBOSE_ARG "$legacyGenGcPath"
|
run rm $VERBOSE_ARG "$legacyGenGcPath"
|
||||||
fi
|
fi
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
|
@ -137,7 +137,7 @@ in {
|
||||||
|
|
||||||
home.activation.createXdgUserDirectories = mkIf cfg.createDirectories (let
|
home.activation.createXdgUserDirectories = mkIf cfg.createDirectories (let
|
||||||
directoriesList = attrValues directories;
|
directoriesList = attrValues directories;
|
||||||
mkdir = (dir: ''$DRY_RUN_CMD mkdir -p $VERBOSE_ARG "${dir}"'');
|
mkdir = (dir: ''run mkdir -p $VERBOSE_ARG "${dir}"'');
|
||||||
in lib.hm.dag.entryAfter [ "linkGeneration" ]
|
in lib.hm.dag.entryAfter [ "linkGeneration" ]
|
||||||
(strings.concatMapStringsSep "\n" mkdir directoriesList));
|
(strings.concatMapStringsSep "\n" mkdir directoriesList));
|
||||||
};
|
};
|
||||||
|
|
|
@ -106,7 +106,7 @@ in {
|
||||||
home.activation.xfconfSettings = hm.dag.entryAfter [ "installPackages" ]
|
home.activation.xfconfSettings = hm.dag.entryAfter [ "installPackages" ]
|
||||||
(let
|
(let
|
||||||
mkCommand = channel: property: value: ''
|
mkCommand = channel: property: value: ''
|
||||||
$DRY_RUN_CMD ${pkgs.xfce.xfconf}/bin/xfconf-query \
|
run ${pkgs.xfce.xfconf}/bin/xfconf-query \
|
||||||
${
|
${
|
||||||
escapeShellArgs ([ "-c" channel "-p" "/${property}" ]
|
escapeShellArgs ([ "-c" channel "-p" "/${property}" ]
|
||||||
++ (if value == null then
|
++ (if value == null then
|
||||||
|
@ -129,7 +129,7 @@ in {
|
||||||
export DBUS_RUN_SESSION_CMD="${pkgs.dbus}/bin/dbus-run-session --dbus-daemon=${pkgs.dbus}/bin/dbus-daemon"
|
export DBUS_RUN_SESSION_CMD="${pkgs.dbus}/bin/dbus-run-session --dbus-daemon=${pkgs.dbus}/bin/dbus-daemon"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
$DRY_RUN_CMD $DBUS_RUN_SESSION_CMD ${load}
|
run $DBUS_RUN_SESSION_CMD ${load}
|
||||||
|
|
||||||
unset DBUS_RUN_SESSION_CMD
|
unset DBUS_RUN_SESSION_CMD
|
||||||
'');
|
'');
|
||||||
|
|
|
@ -163,7 +163,7 @@ in {
|
||||||
(
|
(
|
||||||
export XDG_CACHE_HOME=${escapeShellArg config.xdg.cacheHome}
|
export XDG_CACHE_HOME=${escapeShellArg config.xdg.cacheHome}
|
||||||
$VERBOSE_ECHO "Rebuilding bat theme cache"
|
$VERBOSE_ECHO "Rebuilding bat theme cache"
|
||||||
$DRY_RUN_CMD ${lib.getExe package} cache --build
|
run ${lib.getExe package} cache --build
|
||||||
)
|
)
|
||||||
'';
|
'';
|
||||||
}
|
}
|
||||||
|
|
|
@ -143,7 +143,7 @@ in {
|
||||||
trap "rm --force --recursive $TMP_DIR" EXIT
|
trap "rm --force --recursive $TMP_DIR" EXIT
|
||||||
cp "${ghHosts}" $TMP_DIR/
|
cp "${ghHosts}" $TMP_DIR/
|
||||||
export GH_CONFIG_DIR=$TMP_DIR
|
export GH_CONFIG_DIR=$TMP_DIR
|
||||||
$DRY_RUN_CMD ${getExe cfg.package} help 2>&1 > $DRY_RUN_NULL
|
run --silence ${getExe cfg.package} help
|
||||||
cp $TMP_DIR/hosts.yml "${ghHosts}"
|
cp $TMP_DIR/hosts.yml "${ghHosts}"
|
||||||
)
|
)
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -282,7 +282,7 @@ in {
|
||||||
home.activation = {
|
home.activation = {
|
||||||
createGpgHomedir =
|
createGpgHomedir =
|
||||||
hm.dag.entryBetween [ "linkGeneration" ] [ "writeBoundary" ] ''
|
hm.dag.entryBetween [ "linkGeneration" ] [ "writeBoundary" ] ''
|
||||||
$DRY_RUN_CMD mkdir -m700 -p $VERBOSE_ARG ${escapeShellArg cfg.homedir}
|
run mkdir -m700 -p $VERBOSE_ARG ${escapeShellArg cfg.homedir}
|
||||||
'';
|
'';
|
||||||
|
|
||||||
importGpgKeys = let
|
importGpgKeys = let
|
||||||
|
@ -290,12 +290,11 @@ in {
|
||||||
|
|
||||||
importKey = { source, trust, ... }:
|
importKey = { source, trust, ... }:
|
||||||
# Import mutable keys
|
# Import mutable keys
|
||||||
optional cfg.mutableKeys
|
optional cfg.mutableKeys "run ${gpg} $QUIET_ARG --import ${source}"
|
||||||
"$DRY_RUN_CMD ${gpg} $QUIET_ARG --import ${source}"
|
|
||||||
|
|
||||||
# Import mutable trust
|
# Import mutable trust
|
||||||
++ optional (trust != null && cfg.mutableTrust)
|
++ optional (trust != null && cfg.mutableTrust)
|
||||||
''$DRY_RUN_CMD importTrust "${source}" ${toString trust}'';
|
''run importTrust "${source}" ${toString trust}'';
|
||||||
|
|
||||||
anyTrust = any (k: k.trust != null) cfg.publicKeys;
|
anyTrust = any (k: k.trust != null) cfg.publicKeys;
|
||||||
|
|
||||||
|
|
|
@ -287,7 +287,7 @@ in {
|
||||||
home.activation = mkIf (mbsyncAccounts != [ ]) {
|
home.activation = mkIf (mbsyncAccounts != [ ]) {
|
||||||
createMaildir =
|
createMaildir =
|
||||||
hm.dag.entryBetween [ "linkGeneration" ] [ "writeBoundary" ] ''
|
hm.dag.entryBetween [ "linkGeneration" ] [ "writeBoundary" ] ''
|
||||||
$DRY_RUN_CMD mkdir -m700 -p $VERBOSE_ARG ${
|
run mkdir -m700 -p $VERBOSE_ARG ${
|
||||||
concatMapStringsSep " " (a: a.maildir.absPath) mbsyncAccounts
|
concatMapStringsSep " " (a: a.maildir.absPath) mbsyncAccounts
|
||||||
}
|
}
|
||||||
'';
|
'';
|
||||||
|
|
|
@ -54,7 +54,7 @@ in {
|
||||||
# In theory, mu is the only thing that creates that directory, and it is
|
# In theory, mu is the only thing that creates that directory, and it is
|
||||||
# only created during the initial index.
|
# only created during the initial index.
|
||||||
if [[ ! -d "${dbLocation}" ]]; then
|
if [[ ! -d "${dbLocation}" ]]; then
|
||||||
$DRY_RUN_CMD ${
|
run ${
|
||||||
getExe cfg.package
|
getExe cfg.package
|
||||||
} init ${maildirOption} ${myAddresses} $VERBOSE_ARG;
|
} init ${maildirOption} ${myAddresses} $VERBOSE_ARG;
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -110,13 +110,13 @@ in {
|
||||||
if [[ ! -s "${userConf}" ]]; then
|
if [[ ! -s "${userConf}" ]]; then
|
||||||
# Ensure file's existence
|
# Ensure file's existence
|
||||||
if [[ -v DRY_RUN ]]; then
|
if [[ -v DRY_RUN ]]; then
|
||||||
$DRY_RUN_CMD echo "include ${homeConf}" ">" "${userConf}"
|
run echo "include ${homeConf}" ">" "${userConf}"
|
||||||
else
|
else
|
||||||
echo "include ${homeConf}" > "${userConf}"
|
echo "include ${homeConf}" > "${userConf}"
|
||||||
fi
|
fi
|
||||||
elif ! grep -qF "include ${homeConf}" ${escapeShellArg userConf}; then
|
elif ! grep -qF "include ${homeConf}" ${escapeShellArg userConf}; then
|
||||||
# Add include statement for Home Manager generated config.
|
# Add include statement for Home Manager generated config.
|
||||||
$DRY_RUN_CMD sed -i '1i include ${homeConf}' ${escapeShellArg userConf}
|
run sed -i '1i include ${homeConf}' ${escapeShellArg userConf}
|
||||||
fi
|
fi
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
|
@ -257,9 +257,9 @@ in {
|
||||||
"${extensionPath}/.extensions-immutable.json" = {
|
"${extensionPath}/.extensions-immutable.json" = {
|
||||||
text = extensionJson;
|
text = extensionJson;
|
||||||
onChange = ''
|
onChange = ''
|
||||||
$DRY_RUN_CMD rm $VERBOSE_ARG -f ${extensionPath}/{extensions.json,.init-default-profile-extensions}
|
run rm $VERBOSE_ARG -f ${extensionPath}/{extensions.json,.init-default-profile-extensions}
|
||||||
$VERBOSE_ECHO "Regenerating VSCode extensions.json"
|
$VERBOSE_ECHO "Regenerating VSCode extensions.json"
|
||||||
$DRY_RUN_CMD ${getExe cfg.package} --list-extensions > /dev/null
|
run ${getExe cfg.package} --list-extensions > /dev/null
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
})
|
})
|
||||||
|
|
|
@ -55,17 +55,17 @@ in {
|
||||||
ExecStop = "${dropboxCmd} stop";
|
ExecStop = "${dropboxCmd} stop";
|
||||||
ExecStart = toString (pkgs.writeShellScript "dropbox-start" ''
|
ExecStart = toString (pkgs.writeShellScript "dropbox-start" ''
|
||||||
# ensure we have the dirs we need
|
# ensure we have the dirs we need
|
||||||
$DRY_RUN_CMD ${pkgs.coreutils}/bin/mkdir $VERBOSE_ARG -p \
|
run ${pkgs.coreutils}/bin/mkdir $VERBOSE_ARG -p \
|
||||||
${homeBaseDir}/{.dropbox,.dropbox-dist,Dropbox}
|
${homeBaseDir}/{.dropbox,.dropbox-dist,Dropbox}
|
||||||
|
|
||||||
# symlink them as needed
|
# symlink them as needed
|
||||||
if [[ ! -d ${config.home.homeDirectory}/.dropbox ]]; then
|
if [[ ! -d ${config.home.homeDirectory}/.dropbox ]]; then
|
||||||
$DRY_RUN_CMD ${pkgs.coreutils}/bin/ln $VERBOSE_ARG -s \
|
run ${pkgs.coreutils}/bin/ln $VERBOSE_ARG -s \
|
||||||
${homeBaseDir}/.dropbox ${config.home.homeDirectory}/.dropbox
|
${homeBaseDir}/.dropbox ${config.home.homeDirectory}/.dropbox
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ ! -d ${escapeShellArg cfg.path} ]]; then
|
if [[ ! -d ${escapeShellArg cfg.path} ]]; then
|
||||||
$DRY_RUN_CMD ${pkgs.coreutils}/bin/ln $VERBOSE_ARG -s \
|
run ${pkgs.coreutils}/bin/ln $VERBOSE_ARG -s \
|
||||||
${homeBaseDir}/Dropbox ${escapeShellArg cfg.path}
|
${homeBaseDir}/Dropbox ${escapeShellArg cfg.path}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
|
@ -110,5 +110,5 @@ function systemdPostReload() {
|
||||||
oldGenPath="$1"
|
oldGenPath="$1"
|
||||||
newGenPath="$2"
|
newGenPath="$2"
|
||||||
|
|
||||||
$DRY_RUN_CMD systemctl --user daemon-reload
|
run systemctl --user daemon-reload
|
||||||
systemdPostReload
|
systemdPostReload
|
||||||
|
|
|
@ -19,7 +19,7 @@ in {
|
||||||
|
|
||||||
local f
|
local f
|
||||||
find -L "${fonts}" -type f -printf '%P\0' | while IFS= read -rd "" f; do
|
find -L "${fonts}" -type f -printf '%P\0' | while IFS= read -rd "" f; do
|
||||||
$DRY_RUN_CMD install $VERBOSE_ARG -Dm644 -T \
|
run install $VERBOSE_ARG -Dm644 -T \
|
||||||
"${fonts}/$f" "${homeDir}/Library/Fonts/HomeManager/$f"
|
"${fonts}/$f" "${homeDir}/Library/Fonts/HomeManager/$f"
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
|
@ -38,7 +38,7 @@ in {
|
||||||
home.activation.setCocoaKeybindings =
|
home.activation.setCocoaKeybindings =
|
||||||
hm.dag.entryAfter [ "writeBoundary" ] ''
|
hm.dag.entryAfter [ "writeBoundary" ] ''
|
||||||
$VERBOSE_ECHO "Configuring keybindings for the Cocoa Text System"
|
$VERBOSE_ECHO "Configuring keybindings for the Cocoa Text System"
|
||||||
$DRY_RUN_CMD install -Dm644 $VERBOSE_ARG \
|
run install -Dm644 $VERBOSE_ARG \
|
||||||
"${confFile}" "${homeDir}/Library/KeyBindings/DefaultKeyBinding.dict"
|
"${confFile}" "${homeDir}/Library/KeyBindings/DefaultKeyBinding.dict"
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
|
@ -13,9 +13,9 @@ let
|
||||||
cliFlags = lib.optionalString isLocal "-currentHost";
|
cliFlags = lib.optionalString isLocal "-currentHost";
|
||||||
|
|
||||||
toActivationCmd = domain: attrs:
|
toActivationCmd = domain: attrs:
|
||||||
"$DRY_RUN_CMD /usr/bin/defaults ${cliFlags} import ${
|
"run /usr/bin/defaults ${cliFlags} import ${escapeShellArg domain} ${
|
||||||
escapeShellArg domain
|
toDefaultsFile domain attrs
|
||||||
} ${toDefaultsFile domain attrs}";
|
}";
|
||||||
|
|
||||||
nonNullDefaults =
|
nonNullDefaults =
|
||||||
mapAttrs (domain: attrs: (filterAttrs (n: v: v != null) attrs))
|
mapAttrs (domain: attrs: (filterAttrs (n: v: v != null) attrs))
|
||||||
|
|
|
@ -22,10 +22,10 @@
|
||||||
assertFileContains activate "unset GNUPGHOME QUIET_ARG keyId importTrust"
|
assertFileContains activate "unset GNUPGHOME QUIET_ARG keyId importTrust"
|
||||||
|
|
||||||
assertFileRegex activate \
|
assertFileRegex activate \
|
||||||
'^\$DRY_RUN_CMD @gnupg@/bin/gpg \$QUIET_ARG --import /nix/store/[0-9a-z]*-key1$'
|
'^run @gnupg@/bin/gpg \$QUIET_ARG --import /nix/store/[0-9a-z]*-key1$'
|
||||||
assertFileRegex activate \
|
assertFileRegex activate \
|
||||||
'^\$DRY_RUN_CMD importTrust "/nix/store/[0-9a-z]*-key1" 1$'
|
'^run importTrust "/nix/store/[0-9a-z]*-key1" 1$'
|
||||||
assertFileRegex activate \
|
assertFileRegex activate \
|
||||||
'^\$DRY_RUN_CMD @gnupg@/bin/gpg \$QUIET_ARG --import /nix/store/[0-9a-z]*-key2$'
|
'^run @gnupg@/bin/gpg \$QUIET_ARG --import /nix/store/[0-9a-z]*-key2$'
|
||||||
'';
|
'';
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,6 +19,6 @@
|
||||||
'if [[ ! -d "/home/hm-user/.cache/mu" ]]; then'
|
'if [[ ! -d "/home/hm-user/.cache/mu" ]]; then'
|
||||||
|
|
||||||
assertFileContains activate \
|
assertFileContains activate \
|
||||||
'$DRY_RUN_CMD @mu@/bin/mu init --maildir=/home/hm-user/Mail --my-address=hm@example.com --my-address=foo@example.com $VERBOSE_ARG;'
|
'run @mu@/bin/mu init --maildir=/home/hm-user/Mail --my-address=hm@example.com --my-address=foo@example.com $VERBOSE_ARG;'
|
||||||
'';
|
'';
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue