从git命令捕获输出?

时间:2012-12-05 02:11:37

标签: bash capture output

我正在编写一个脚本来自动为我设置新项目。

这包括拉下github存储库。

我想要做的是从我的脚本获得一些输出,然后调用git clone $repo

我想在该命令运行时显示该命令的输出,但是当它运行成功时,如果它已成功运行替换它的输出(请注意git命令输出,我仍然希望之前的输出在那里)repository successfully cloned如果失败,只需将输出保留在那里,然后打印repository cloning failed

我该怎么做?

以下是我当前(相当简单)的脚本。

#! /bin/bash

# -p project name

templateurl="git@bitbucket.org:xxx/xxx-site-template.git"

while getopts ":p:" opt; do #eventually I'll add more options here

case $opt in
  p)
    project=$OPTARG
    ;;
  \?)
    echo "Invalid option: -$OPTARG" >&2
    exit 1
    ;;
  :)
    echo "Option -$OPTARG requires an argument." >&2
    exit 1
    ;;
esac
done

if [ -z "$project" ]; then
    echo "Project name required"
    exit 1
fi

clear
echo "|==========================|"
echo "| New xxx Project Creator  |"
echo "|==========================|"
echo "Project: $project"

if [ -d "$project" ]; then
    echo "Directory $project already exists!"
    exit 1
fi


mkdir $project
if [ ! -d "$project" ]; then
    echo "Failed to create project directory!"
    exit 1
fi

echo "Cloning xxx Template repository"
git clone $templateurl $project

2 个答案:

答案 0 :(得分:10)

git clone确实提供了一个可以用$读取的退出代码?如下:

git clone user@server:repo
echo $?

如果一切正常,这将打印0。例如,如果文件夹不是git存储库,您将获得退出代码128。

您可以检查克隆是否如下工作:

git clone user@server:repo localrepo --quiet
success=$?
if [[ $success -eq 0 ]];
then
    echo "Repository successfully cloned."
else
    echo "Something went wrong!"
fi
只要没有错误,

--quiet将禁止git的任何输出。因此,如果您只是删除else分支,您将获得正输出或git产生的错误。

答案 1 :(得分:4)

git clone user@server:repo localrepo > git.log 2>&1
if [[ $? eq 0 ]];
then
   echo Repository successfully cloned.
else
   cat git.log
   echo Repository cloning failed.
fi

rm git.log

<强>解释

git clone user@server:repo localrepo > git.log 2>&1 将stdout和stderr流重定向到git.log。 > git.log将stdout重定向到git.log 2>&1将stderr重定向到与stdout相同的位置(因此,git.log)。

$? eq 0检查git的重新编码,如果克隆成功则应为0。

cat git.log输出git.log文件的内容。