From 8e1e823cd160145fda3921d75ecac767bcd5e9d8 Mon Sep 17 00:00:00 2001 From: Daniel Friesel Date: Sat, 6 Sep 2008 09:57:40 +0200 Subject: Added 'conflicts' to check for double path entries --- include/conflicts | 41 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100755 include/conflicts diff --git a/include/conflicts b/include/conflicts new file mode 100755 index 0000000..12d916d --- /dev/null +++ b/include/conflicts @@ -0,0 +1,41 @@ +#!/usr/bin/env zsh +## vim:ft=zsh +typeset file dir conflict i +typeset PDIR=$HOME/packages +typeset -a sfpath spath + +is_in_path () { + typeset -i ret=1 + typeset dir + typeset file=$1 + shift + for dir in $@; { + if [[ -e $dir/$file ]] { + ret=0 + echo $dir/$file + } + } + return $ret +} + +# a simple sfpath=${fpath:#/home/derf*} won't work +for i in ${fpath:#/home/derf*}; { + sfpath+=$i +} +for i in ${path:#/home/derf*}; { + spath+=$i +} + +for file in $PDIR/{*/provides/zsh/completions/*(N),zsh/etc/completions/*(N)}; { + conflict=$(is_in_path ${file:t} $sfpath) + if (( ? == 0 )) { + echo "conflict: $file <-> $conflict" + } +} + +for file in $PDIR/*/bin/*(N); { + conflict=$(is_in_path ${file:t} $spath) + if (( ? == 0 )) { + echo "conflict: $file <-> $conflict" + } +} -- cgit v1.2.3