在命令行中,svn 中不像 git 可以使用一个文件对仓库要屏蔽的文件进行管理,网上有很多这方面的命令教程:
但这并不是我想要的效果,所以我自己实现了一个简单的svnignore文件管理来对svn仓库中的 status 显示进行管理。
效果即为那些我不想要显示在 svn status
中的便不显示。因此我重新写了一个命令来达到此目的。而且当 status 的结果很多时,需要上下翻屏比较麻烦,所以我使用了一个缓存的文件来保存 status 结果。
具体如下:
- 将附录A的代码copy到
~/.bashrc
中,并执行 命令:source ~/.bashrc
; - 在仓库下创建一个
.svnignore
文件,文件中每一行为要屏蔽的文件名,不能包含/
!参照附录B;
附录A:
CACHE_TMP="$HOME/.cache/tmp"
# 更方便的查看 diff ,同时保存起来
__init_git_svn(){
if [ ! -d $CACHE_TMP/git-diff ];then mkdir -p $CACHE_TMP/git-diff;fi
if [ ! -d $CACHE_TMP/svn-diff ];then mkdir -p $CACHE_TMP/svn-diff;fi
if [ ! -d $CACHE_TMP/git-st ];then mkdir -p $CACHE_TMP/git-st;fi
if [ ! -d $CACHE_TMP/svn-st ];then mkdir -p $CACHE_TMP/svn-st;fi
}
gdf(){ __init_git_svn; now=`date +%Y%m%d-%H%M%S`.log;fl=$CACHE_TMP/git-diff/$now;git diff $@ > $fl;vim -M $fl; }
sdf(){ __init_git_svn; now=`date +%Y%m%d-%H%M%S`.log;fl=$CACHE_TMP/svn-diff/$now;svn diff $@ > $fl;vim -M $fl; }
gsg(){ __init_git_svn; now=`date +%Y%m%d-%H%M%S`.log;fl=$CACHE_TMP/git-st/$now;git status $@ > $fl;vim -M $fl; }
ssg(){ __init_git_svn; now=`date +%Y%m%d-%H%M%S`.log; fl=$CACHE_TMP/svn-st/$now; fl0=$fl".log";
svn status $@ > $fl0
cat ".svnignore" | while read line;do
if [ -z $line ];then continue;fi;
echo "$line"x| grep -q "^\s";test $? -eq 0 && continue
sed "/$line/d" $fl0 > $fl;
mv $fl $fl0;
done
mv $fl0 $fl;
vim -M $fl;
}
dif(){ diff -y $@ | less; }
# 清除所有log
alias gdfclear="rm $CACHE_TMP/git-diff/*"
alias sdfclear="rm $CACHE_TMP/svn-diff/*"
alias gdfls="ls $CACHE_TMP/git-diff/"
alias sdfls="ls $CACHE_TMP/svn-diff/"
alias gst="git status"
# svn 只显示修改
alias sst="svn status"
alias ssq="svn status -q"
查看无 屏蔽文件效果的 svn status
使用 ssg
命令替代!
附录B(文件 .svnignore
的内容):
log
update
sh.sh
stop
tmp_eval_file.c
.svnignore
start
tmp
.workspace.vim
dat
null
act_20378.txt
act_20379.py
act_20378.py
ls.cfg
config_ls.cfg
tags
切记,此文件不能出现斜杠 /
字符!这也是一个不完善的地方,还请大神指点如何解决。
网友评论