Refactor pj function
- Use `emulate -L zsh` to make all variables local. - Use `shwordsplit` to interpret `$cmd` spaces correctly. - Rename `$project` and `$file` variables to the more appropriate `$basedir` and `$project`.
This commit is contained in:
parent
c9c11d605f
commit
7f8851f52f
1 changed files with 15 additions and 13 deletions
|
@ -1,29 +1,31 @@
|
|||
alias pjo="pj open"
|
||||
|
||||
function pj () {
|
||||
cmd="cd"
|
||||
file=$1
|
||||
pj () {
|
||||
emulate -L zsh
|
||||
setopt shwordsplit
|
||||
|
||||
if [[ "open" == "$file" ]] then
|
||||
cmd="cd"
|
||||
project=$1
|
||||
|
||||
if [[ "open" == "$project" ]]; then
|
||||
shift
|
||||
file=$*
|
||||
cmd=(${(s: :)EDITOR})
|
||||
project=$*
|
||||
cmd=$EDITOR
|
||||
else
|
||||
file=$*
|
||||
project=$*
|
||||
fi
|
||||
|
||||
for project in $PROJECT_PATHS; do
|
||||
if [[ -d $project/$file ]] then
|
||||
$cmd "$project/$file"
|
||||
unset project # Unset project var
|
||||
for basedir ($PROJECT_PATHS); do
|
||||
if [[ -d "$basedir/$project" ]]; then
|
||||
$cmd "$basedir/$project"
|
||||
return
|
||||
fi
|
||||
done
|
||||
|
||||
echo "No such project $1"
|
||||
echo "No such project '${project}'."
|
||||
}
|
||||
|
||||
function _pj () {
|
||||
_pj () {
|
||||
emulate -L zsh
|
||||
|
||||
typeset -a projects
|
||||
|
|
Loading…
Reference in a new issue