bashrc_增加git信息显示_3_2
此版本功能
1. 相对版本3-1,增加本地与远端文件量数
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
function parse_git_dirty {
local git_status=$(git status 2> /dev/null);
local modify_file_num=0;
local commit_file_num=0;
local change_file_num=0;
local untracked_file_num=0;
#if [[ "${git_status}" =~ "nothing to commit, working tree clean" ]]; then
# echo ""
# exit 0
#fi
if [[ "${git_status}" =~ "Changes not staged for commit" ]]; then
# 有修改的文件
modify_file_num=$( git diff --name-only 2> /dev/null | wc -l | tr -d ' ' )
fi
if [[ "${git_status}" =~ "Changes to be committed" ]]; then
# 有要提交的文件
commit_file_num=$( git diff --cached --name-only 2> /dev/null | wc -l | tr -d ' ' )
fi
if [[ "${git_status}" =~ "Untracked files" ]]; then
# 存在改动的文件
change_file_num=$( cd $( git rev-parse --show-toplevel ); git ls-files --others --exclude-standard 2> /dev/null | wc -l | tr -d ' ' )
fi
#echo -e "\[\033[01;32m\]A:\[\033[01;31m\]${commit_file_num} \[\033[01;32m\]M:\[\033[01;31m\]${modify_file_num} \[\033[01;32m\]+:\[\033[01;31m\]${change_file_num}\[\033[01;31m\]";
# \[\033[0;32m\]A 由这个0;32m 将后面的字体都变成正常体(非粗体)
echo -e "\[\033[0;32m\]A:\[\033[31m\]${commit_file_num} \[\033[32m\]M:\[\033[31m\]${modify_file_num} \[\033[32m\]+:\[\033[31m\]${change_file_num}\[\033[31m\]";
}
function git_branch()
{
branch=$( git rev-parse --abbrev-ref HEAD 2>/dev/null )
if [ "${branch}" != "" ]; then
if [ "${branch}" = "(no branch)" ]; then
branch="($( git rev-parse --short HEAD )...)"
fi
# 本地与远端文件量差
## 获取远程仓库的最新信息,但不改变本地状态
diff_file_num=$( git diff HEAD..origin --name-only | wc -l | tr -d ' ' )
echo -e "⎇ \[\033[01;33m\]${branch} \[\033[01;36m\][ $(parse_git_dirty) \[\033[01;36m\]] \[\033[0;32m\]↓:\[\033[31m\]${diff_file_num} \[\033[01;36m\]"
fi
}
function prompt_command {
PS1="\n\[\033[01;36m\][\u@\h\[\033[01;32m\] \w\[\033[01;36m\]]\[\033[01;36m\] $(git_branch)\[\033[00m\]\n\\$\[\033[00m\] "
}
PROMPT_COMMAND=prompt_command
export CLICOLOR=1
export LSCOLORS=ExGxFxdaCxDaDahbadache
#后面与其他的一样
...
...
...
配合定时任务: 定时更新本地仓库与远端仓库信息(不拉取)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#!/bin/bash
# /path/to/path/git_fetch_origin.sh
# * * * * * /path/to/path/git_fetch_origin.sh
# local 本地仓库目录
gitdir="/path/to/path/XTgit /path/to/path/FSGit"
# 找出的当前目录下一级的目录,不包含自身
for dirname in $( find ${gitdir} -mindepth 1 -maxdepth 1 -type d )
do
cd "${dirname}"
if [ -d .git ]; then
#echo ${dirname}
#git fetch origin
is_status=$( git fetch origin 2>&1 )
if [ $? -ne 0 ]; then
dingTalk 1 "[${dirname}] Git同步本地与远端: ${is_status}"
exit 0
fi
fi
done
[[Script/send_DingTalk/dingTalk]]
本文由作者按照
CC BY 4.0
进行授权