X-Git-Url: https://iankelling.org/git/?p=lnf;a=blobdiff_plain;f=lnf-function;h=7bc88f0c5847ccab79a067b7c3b1ad7313eb6b7b;hp=04fe9242c35f80e8cb579e7d85a9e0fa14dae919;hb=a5d3fe7ecee597e33e7081f45847a6c9f25a22fb;hpb=15c4639b1ee74247ac931088eea77e3ea37ba7c3 diff --git a/lnf-function b/lnf-function index 04fe924..7bc88f0 100644 --- a/lnf-function +++ b/lnf-function @@ -6,7 +6,9 @@ lnf() { local help="lnf [--help] LN_ARGUMENTS... Create symlinks conveniently and forcefully. Remove existing file/links using trash-put or rm -rf if it is not available. -Create directory if needed. Finally, ln -s -- LN_ARGUMENTS" +Create directory if needed. Small change to ln argument semantics: for 2 arguments, +the second is the link, never a directory to put the link in. +LN_ARGUMENTS are passed to ln -s --, meaning no ln option arguments are supported." if [[ $1 == --help ]]; then echo "$help" return 0 @@ -19,19 +21,21 @@ Create directory if needed. Finally, ln -s -- LN_ARGUMENTS" remove="rm -rf" fi - if [[ $# -ge 3 && ! -d ${!#} ]]; then - mkdir -p "${!#}" - elif [[ $# -ge 2 && -d ${!#} ]]; then - local oldcwd=$PWD - cd ${!#} # last arg - for x in "${@:1:$(($#-1))}"; do # all but last arg - # remove any trailing slashes - x="${x%%+(/)}" - # remove any leading directory components - x="${x##*/}" - [[ -e "$x" || -L "$x" ]] && $remove "$x" - done - cd "$oldcwd" + if [[ $# -ge 3 ]]; then + if [[ -d ${!#} ]]; then + local oldcwd=$PWD + cd ${!#} # last arg + for x in "${@:1:$(($#-1))}"; do # all but last arg + # remove any trailing slashes + x="${x%%+(/)}" + # remove any leading directory components + x="${x##*/}" + [[ -e "$x" || -L "$x" ]] && $remove "$x" + done + cd "$oldcwd" + else + mkdir -p "${!#}" + fi elif [[ $# -eq 2 ]]; then if [[ -e "$2" || -L "$2" ]]; then $remove "$2"