sh:parse_git_branch:找不到命令

Posted

技术标签:

【中文标题】sh:parse_git_branch:找不到命令【英文标题】:sh: parse_git_branch: command not found 【发布时间】:2016-02-25 04:40:55 【问题描述】:

我在 osx El Captain 上启用了 root。我尝试了*** 和supersu 上已经提供的一些解决方案,但无法修复错误。我从.bash_promptfunction parse_git_branch() 导出到.bash_profile,但我仍然收到此错误。我不知道 bash 脚本,所以我不知道发生了什么以及要修复什么。

abhimanyuaryan at Macbook in ~
$ sudo su
sh: parse_git_branch: command not found
root at Macbook in /Users/abhimanyuaryan

.bash_profile

if which rbenv > /dev/null; then eval "$(rbenv init -)"; fi

# Add Homebrew `/usr/local/bin` and User `~/bin` to the `$PATH`
PATH=/usr/local/bin:$PATH
PATH=$HOME/bin:$PATH
export PATH

# Load the shell dotfiles, and then some:
# * ~/.path can be used to extend `$PATH`.
# * ~/.extra can be used for other settings you don’t want to commit.
for file in ~/.path,bash_prompt,exports,aliases,functions,extra; do
  [ -r "$file" ] && source "$file"
done
unset file

.bash_prompt

# @gf3’s Sexy Bash Prompt, inspired by “Extravagant Zsh Prompt”
# Shamelessly copied from https://github.com/gf3/dotfiles
# Screenshot: http://i.imgur.com/s0Blh.png

if [[ $COLORTERM = gnome-* && $TERM = xterm ]] && infocmp gnome-256color >/dev/null 2>&1; then
  export TERM=gnome-256color
elif infocmp xterm-256color >/dev/null 2>&1; then
  export TERM=xterm-256color
fi

if tput setaf 1 &> /dev/null; then
  tput sgr0
  if [[ $(tput colors) -ge 256 ]] 2>/dev/null; then
    # Changed these colors to fit Solarized theme
    MAGENTA=$(tput setaf 125)
    ORANGE=$(tput setaf 166)
    GREEN=$(tput setaf 64)
    PURPLE=$(tput setaf 61)
    WHITE=$(tput setaf 244)
  else
    MAGENTA=$(tput setaf 5)
    ORANGE=$(tput setaf 4)
    GREEN=$(tput setaf 2)
    PURPLE=$(tput setaf 1)
    WHITE=$(tput setaf 7)
  fi
  BOLD=$(tput bold)
  RESET=$(tput sgr0)
else
  MAGENTA="\033[1;31m"
  ORANGE="\033[1;33m"
  GREEN="\033[1;32m"
  PURPLE="\033[1;35m"
  WHITE="\033[1;37m"
  BOLD=""
  RESET="\033[m"
fi

export MAGENTA
export ORANGE
export GREEN
export PURPLE
export WHITE
export BOLD
export RESET

function parse_git_dirty() 
  [[ $(git status 2> /dev/null | tail -n1) != *"working directory clean"* ]] && echo "*"


function parse_git_branch() 
  git branch --no-color 2> /dev/null | sed -e '/^[^*]/d' -e "s/* \(.*\)/\1$(parse_git_dirty)/"


export PS1="\[$BOLD$MAGENTA\]\u \[$WHITE\]at \[$ORANGE\]\h \[$WHITE\]in \[$GREEN\]\w\[$WHITE\]\$([[ -n \$(git branch 2> /dev/null) ]] && echo \" on \")\[$PURPLE\]\$(parse_git_branch)\[$WHITE\]\n\$ \[$RESET\]"
export PS2="\[$ORANGE\]→ \[$RESET\]"

【问题讨论】:

【参考方案1】:

这里的问题是,当您执行sudo su 时,您正在更改为 root,但您保留了自己的个人资料。该配置文件包含一个引用 bash 函数的命令提示符设置。但是当你 sudo 到 root 时,你得到的是 root 的 shell,它是 sh 而不是 bash - 所以任何依赖 bash 配置的修改都将不起作用,包括你在 PS1 中引用的函数。

因此,首先要做的是确保您在 sudo 时实际运行的是 bash 而不是 sh。这非常简单——您只需运行sudo bash,而不是运行sudo su

由于 sudo 默认切换到 root,您现在将以 root 身份运行 bash shell,而不仅仅是切换到 root 用户的默认 shell。

如果您仍然有问题,这可能是由于您的 .bash_profile 包含对当前用户主目录的引用,因为它在这些行中指向 ~

for file in ~/.path,bash_prompt,exports,aliases,functions,extra; do
  [ -r "$file" ] && source "$file"
done

当您以自己的身份运行 bash 时,~ 将扩展到您自己的主目录 - 但当您以 root 身份运行它时,它将评估为 /var/root,它会在那里查找您的文件。

您可以通过三种方式解决此问题;选择你喜欢的那个。

    更改 .bash_profile,使其包含主目录的完整路径,而不仅仅是波浪号 将所有相关的bash文件复制到/var/root 不要运行sudo su,而是运行sudo su -。这将为您提供 root 的环境,而不是您自己的环境。缺点是您自己的所有环境修改都将不可用,您将运行sh 而不是bash。 (在某些操作系统中,它们是相同的,但在其他操作系统中则不同。我相信 MacOSX 是其中shbash 不同的操作系统之一。)

【讨论】:

我使用的是 Mac。我没有.bashrc。我有 bash_profile。都一样吗? 是一样的。我将编辑我的答案以消除混淆。 已修复。在过去的一周里,我一直在使用 Linux、MacOSX 和 FreeBSD,有时我会混淆文件名放在哪里...... 是命令行提示符的格式。在您的文件.bash_prompt 的末尾,有一行以export PS1 开头 - 这是您定义提示应包含函数parse_git_branch 的地方。 正确;因为root shell 几乎可以肯定是/bin/sh,所以它不会执行任何启动文件; sudo -isu -l 将指定模拟登录,这意味着将执行 /etc/profile.profile【参考方案2】:

你导出你的 $PS1 了吗? 可以通过运行命令查看:

printenv

否则你应该通过运行导出它:

export -n PS1

之后你就可以毫无问题地运行 sudo 或 sudo su

【讨论】:

以上是关于sh:parse_git_branch:找不到命令的主要内容,如果未能解决你的问题,请参考以下文章

sh: husky: 找不到命令

sh:symfony-cmd:找不到命令

sh:SET:在`npm start`中找不到命令

在 sh shell 中找不到源命令

/bin/sh: pkg-config: 找不到命令

sh:转换:在 spyder 上找不到命令