diff options
| author | Robby Russell <robby@planetargon.com> | 2011-10-10 05:24:38 -0700 | 
|---|---|---|
| committer | Robby Russell <robby@planetargon.com> | 2011-10-10 05:24:38 -0700 | 
| commit | 7b6b6f1d923fbe9138e449ca4e05e67aebaae26a (patch) | |
| tree | a97d3a1a8d5f389bfbf22632cecdbce7b75c2f07 /plugins/gnu-utils | |
| parent | 84c20ce6ddfddf4c0250288ac0ba4cebb936208c (diff) | |
| parent | bf86502b6940d938c488254befdf9461cb50591b (diff) | |
| download | zsh-7b6b6f1d923fbe9138e449ca4e05e67aebaae26a.tar.gz zsh-7b6b6f1d923fbe9138e449ca4e05e67aebaae26a.tar.bz2 zsh-7b6b6f1d923fbe9138e449ca4e05e67aebaae26a.zip | |
Merge pull request #205 from sorin-ionescu/plugin-gnu-utils
gnu-utils plugin
Diffstat (limited to 'plugins/gnu-utils')
| -rw-r--r-- | plugins/gnu-utils/gnu-utils.plugin.zsh | 80 | 
1 files changed, 80 insertions, 0 deletions
| diff --git a/plugins/gnu-utils/gnu-utils.plugin.zsh b/plugins/gnu-utils/gnu-utils.plugin.zsh new file mode 100644 index 000000000..e59265d66 --- /dev/null +++ b/plugins/gnu-utils/gnu-utils.plugin.zsh @@ -0,0 +1,80 @@ +# ------------------------------------------------------------------------------ +#          FILE:  gnu-utils.plugin.zsh +#   DESCRIPTION:  oh-my-zsh plugin file. +#        AUTHOR:  Sorin Ionescu (sorin.ionescu@gmail.com) +#       VERSION:  1.0.0 +# ------------------------------------------------------------------------------ + + +if [[ -x "${commands[gwhoami]}" ]]; then  +  __gnu_utils() { +    emulate -L zsh +    local gcmds +    local gcmd +    local cmd +    local prefix + +    # coreutils  +    gcmds=('g[' 'gbase64' 'gbasename' 'gcat' 'gchcon' 'gchgrp' 'gchmod' +    'gchown' 'gchroot' 'gcksum' 'gcomm' 'gcp' 'gcsplit' 'gcut' 'gdate' +    'gdd' 'gdf' 'gdir' 'gdircolors' 'gdirname' 'gdu' 'gecho' 'genv' 'gexpand' +    'gexpr' 'gfactor' 'gfalse' 'gfmt' 'gfold' 'ggroups' 'ghead' 'ghostid' +    'gid' 'ginstall' 'gjoin' 'gkill' 'glink' 'gln' 'glogname' 'gls' 'gmd5sum' +    'gmkdir' 'gmkfifo' 'gmknod' 'gmktemp' 'gmv' 'gnice' 'gnl' 'gnohup' 'gnproc' +    'god' 'gpaste' 'gpathchk' 'gpinky' 'gpr' 'gprintenv' 'gprintf' 'gptx' 'gpwd' +    'greadlink' 'grm' 'grmdir' 'gruncon' 'gseq' 'gsha1sum' 'gsha224sum' +    'gsha256sum' 'gsha384sum' 'gsha512sum' 'gshred' 'gshuf' 'gsleep' 'gsort' +    'gsplit' 'gstat' 'gstty' 'gsum' 'gsync' 'gtac' 'gtail' 'gtee' 'gtest' +    'gtimeout' 'gtouch' 'gtr' 'gtrue' 'gtruncate' 'gtsort' 'gtty' 'guname' +    'gunexpand' 'guniq' 'gunlink' 'guptime' 'gusers' 'gvdir' 'gwc' 'gwho' +    'gwhoami' 'gyes') + +    # Not part of coreutils, installed separately. +    gcmds+=('gsed' 'gtar' 'gtime') + +    for gcmd in "${gcmds[@]}"; do +      # +      # This method allows for builtin commands to be primary but it's +      # lost if hash -r or rehash -f is executed. Thus, those two  +      # functions have to be wrapped. +      # +      (( ${+commands[$gcmd]} )) && hash ${gcmd[2,-1]}=${commands[$gcmd]} + +      # +      # This method generates wrapper functions. +      # It will override shell builtins. +      # +      # (( ${+commands[$gcmd]} )) && \ +      # eval "function $gcmd[2,-1]() { \"${prefix}/${gcmd//"["/"\\["}\" \"\$@\"; }" + +      # +      # This method is inflexible since the aliases are at risk of being +      # overriden resulting in the BSD coreutils being called. +      # +      # (( ${+commands[$gcmd]} )) && \ +      # alias "$gcmd[2,-1]"="${prefix}/${gcmd//"["/"\\["}" +    done + +    return 0 +  } +  __gnu_utils; + +  function hash() { +    if [[ "$*" =~ "-(r|f)" ]]; then +      builtin hash "$@" +      __gnu_utils +    else +      builtin hash "$@" +    fi +  } + +  function rehash() { +    if [[ "$*" =~ "-f" ]]; then +      builtin rehash "$@" +      __gnu_utils +    else +      builtin rehash "$@" +    fi +  } +fi + | 
