From: Richard Hartmann Date: Fri, 10 Feb 2012 17:14:42 +0000 (+0100) Subject: Merge branch 'which' X-Git-Url: https://git.madduck.net/code/vcsh.git/commitdiff_plain/d6910eed1ad1ae786b997863ff133cac61e490c3?hp=33de26d293a95451545def939ddbeb287d068cc8 Merge branch 'which' --- diff --git a/doc/vcsh.1.ronn b/doc/vcsh.1.ronn index 17be1a9..cc66e07 100644 --- a/doc/vcsh.1.ronn +++ b/doc/vcsh.1.ronn @@ -25,6 +25,8 @@ vcsh(1) - manage config files in $HOME via fake bare git repositories `vcsh` setup +`vcsh` which + `vcsh` write-gitignore `vcsh` @@ -98,6 +100,9 @@ an interactive user. * setup: Set up repository with recommended settings. +* which : + Find in name of any tracked file. + * write-gitignore: Write .gitignore.d/ via git ls-files. diff --git a/vcsh b/vcsh index 3a8fefc..86e88f0 100755 --- a/vcsh +++ b/vcsh @@ -35,6 +35,7 @@ help() { run \\ Use this repository setup Set up repository with recommended settings + which Find substring in name of any tracked file write-gitignore \\ Write .gitignore.d/ via git ls-files @@ -183,6 +184,14 @@ use() { export VCSH_DIRECTORY="$VCSH_REPO_NAME" } +which() { + for VCSH_REPO_NAME in $(list); do + for VCSH_FILE in $(get_files); do + echo $VCSH_FILE | grep -q "$VCSH_COMMAND_PARAMETER" && echo "$VCSH_REPO_NAME: $VCSH_FILE" + done + done | sort -u +} + write_gitignore() { use cd "$VCSH_BASE" || fatal "could not enter '$VCSH_BASE'" 11 @@ -225,6 +234,11 @@ if [ "$1" = 'clone' ]; then [ -n "$3" ] && VCSH_REPO_NAME="$3" || VCSH_REPO_NAME=$(basename "$GIT_REMOTE" .git) export VCSH_REPO_NAME export GIT_DIR="$VCSH_REPO_D/$VCSH_REPO_NAME.git" +elif [ "$1" = 'which' ]; then + [ -z "$2" ] && fatal "$1: please specify a filename" 1 + [ -n "$3" ] && fatal "$1: too many parameters" 1 + export VCSH_COMMAND="$1" + export VCSH_COMMAND_PARAMETER="$2" elif [ "$1" = 'delete' ] || [ "$1" = 'enter' ] || [ "$1" = 'init' ] ||