diff options
author | Benjamin Staffin <ben@folsomlabs.com> | 2015-02-17 17:02:25 -0800 |
---|---|---|
committer | Benjamin Staffin <ben@folsomlabs.com> | 2015-02-17 17:21:55 -0800 |
commit | 92aef0621f4e383a290322724c31f302a811b053 (patch) | |
tree | 5fc3ce3f5707caf15e1d32eb6871b4a9fdeda0a6 /maintainers/scripts/update-channel-branches.sh | |
parent | c08716029b1be561967338cb9adce338a67d5d05 (diff) | |
download | nixpkgs-92aef0621f4e383a290322724c31f302a811b053.tar nixpkgs-92aef0621f4e383a290322724c31f302a811b053.tar.gz nixpkgs-92aef0621f4e383a290322724c31f302a811b053.tar.bz2 nixpkgs-92aef0621f4e383a290322724c31f302a811b053.tar.lz nixpkgs-92aef0621f4e383a290322724c31f302a811b053.tar.xz nixpkgs-92aef0621f4e383a290322724c31f302a811b053.tar.zst nixpkgs-92aef0621f4e383a290322724c31f302a811b053.zip |
update-channel-branches: fix to work with posix /bin/sh
Should now work equally well with bash (as on NixOS) and dash (on various other distributions). The only truly required change was on line 10: "function" is a superfluous keyword that's not present in posix sh. Change-Id: If917499b2e24c0d039e8c61208227b90c9fc5c0d
Diffstat (limited to 'maintainers/scripts/update-channel-branches.sh')
-rwxr-xr-x | maintainers/scripts/update-channel-branches.sh | 25 |
1 files changed, 13 insertions, 12 deletions
diff --git a/maintainers/scripts/update-channel-branches.sh b/maintainers/scripts/update-channel-branches.sh index 5dbbec9393c..d65cf3ec5f6 100755 --- a/maintainers/scripts/update-channel-branches.sh +++ b/maintainers/scripts/update-channel-branches.sh @@ -1,13 +1,14 @@ #!/bin/sh +set -e : ${NIXOS_CHANNELS:=https://nixos.org/channels/} : ${CHANNELS_NAMESPACE:=refs/heads/channels/} # List all channels which are currently in the repository which we would # have to remove if they are not found again. -deadChannels=$(git for-each-ref --format="%(refname)" $CHANNELS_NAMESPACE) +deadChannels=$(git for-each-ref --format="%(refname)" "$CHANNELS_NAMESPACE") -function updateRef() { +updateRef() { local channelName=$1 local newRev=$2 @@ -17,9 +18,9 @@ function updateRef() { # Update the local refs/heads/channels/* branches to be in-sync with the # channel references. local branch=$CHANNELS_NAMESPACE$channelName - oldRev=$(git rev-parse --short $branch 2>/dev/null || true) + oldRev=$(git rev-parse --short "$branch" 2>/dev/null || true) if test "$oldRev" != "$newRev"; then - if git update-ref $branch $newRev 2>/dev/null; then + if git update-ref "$branch" "$newRev" 2>/dev/null; then if test -z "$oldRev"; then echo " * [new branch] $newRev -> ${branch#refs/heads/}" else @@ -35,21 +36,21 @@ function updateRef() { fi # Filter out the current channel from the list of dead channels. - deadChannels=$(grep -v $CHANNELS_NAMESPACE$channelName <<EOF + deadChannels=$(grep -v "$CHANNELS_NAMESPACE$channelName" <<EOF $deadChannels EOF -) +) ||true } # Find the name of all channels which are listed in the directory. echo "Fetching channels from $NIXOS_CHANNELS:" -for channelName in : $(curl -s $NIXOS_CHANNELS | sed -n '/folder/ { s,.*href=",,; s,/".*,,; p }'); do +for channelName in : $(curl -s "$NIXOS_CHANNELS" | sed -n '/folder/ { s,.*href=",,; s,/".*,,; p }'); do test "$channelName" = : && continue; # Do not follow redirections, such that we can extract the # short-changeset from the name of the directory where we are # redirected to. - sha1=$(curl -sI $NIXOS_CHANNELS$channelName | sed -n '/Location/ { s,.*\.\([a-f0-9]*\)[ \r]*$,\1,; p; }') + sha1=$(curl -sI "$NIXOS_CHANNELS$channelName" | sed -n '/Location/ { s,.*\.\([a-f0-9]*\)[ \r]*$,\1,; p; }') updateRef "remotes/$channelName" "$sha1" done @@ -60,13 +61,13 @@ if currentSystem=$(nixos-version 2>/dev/null); then # then the version is not annotated in git version. This sed # expression is basically matching that the expressions end with # ".<sha1> (Name)" to extract the sha1. - sha1=$(echo $currentSystem | sed -n 's,^.*\.\([a-f0-9]*\) *(.*)$,\1,; T skip; p; :skip;') + sha1=$(echo "$currentSystem" | sed -n 's,^.*\.\([a-f0-9]*\) *(.*)$,\1,; T skip; p; :skip;') updateRef current-system "$sha1" fi -echo "Fetching channels from ~/.nix-defexpr:" -for revFile in : $(find -L ~/.nix-defexpr/ -maxdepth 4 -name svn-revision); do +echo "Fetching channels from $HOME/.nix-defexpr:" +for revFile in : $(find -L "$HOME/.nix-defexpr/" -maxdepth 4 -name svn-revision); do test "$revFile" = : && continue; # Deconstruct a path such as, into: @@ -85,7 +86,7 @@ for revFile in : $(find -L ~/.nix-defexpr/ -maxdepth 4 -name svn-revision); do test -z "$user" && user=$USER channelName="$user${user:+/}$repo" - sha1=$(cat $revFile | sed -n 's,^.*\.\([a-f0-9]*\)$,\1,; T skip; p; :skip;') + sha1=$(sed -n 's,^.*\.\([a-f0-9]*\)$,\1,; T skip; p; :skip;' "$revFile") updateRef "$channelName" "$sha1" done |