git:https-and-ssh: Make POSIX-shell compliant
Don't know why this had two shebangs and how I never noticed. Apparently I only launched the script through the autoloaded function in zsh.
This commit is contained in:
@@ -1,5 +1,4 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
#!/usr/bin/zsh
|
|
||||||
|
|
||||||
# Sets up given remote (or origin) so that it fetches over https but pushes over
|
# Sets up given remote (or origin) so that it fetches over https but pushes over
|
||||||
# ssh. This way unlocking the ssh key is only needed when really necessary.
|
# ssh. This way unlocking the ssh key is only needed when really necessary.
|
||||||
@@ -10,12 +9,12 @@ remote="${1:-origin}"
|
|||||||
url="$($GIT remote get-url "$remote")"
|
url="$($GIT remote get-url "$remote")"
|
||||||
|
|
||||||
if [ "${url##https://}" = "$url" ]; then
|
if [ "${url##https://}" = "$url" ]; then
|
||||||
https_url="${url##*@}"
|
https_url="https://${url##*@}"
|
||||||
https_url="https://${https_url/://}"
|
https_url="${https_url%%:*}/${https_url#*:}"
|
||||||
$GIT remote set-url "$remote" "$https_url"
|
$GIT remote set-url "$remote" "$https_url"
|
||||||
$GIT remote set-url --push "$remote" "$url"
|
$GIT remote set-url --push "$remote" "$url"
|
||||||
else
|
else
|
||||||
ssh_url="${url##https://}"
|
ssh_url="git@${url#https://}"
|
||||||
ssh_url="git@${ssh_url/\//:}"
|
ssh_url="${ssh_url%%/*}:${ssh_url#*/}"
|
||||||
$GIT remote set-url --push "$remote" "$ssh_url"
|
$GIT remote set-url --push "$remote" "$ssh_url"
|
||||||
fi
|
fi
|
||||||
|
|||||||
Reference in New Issue
Block a user