SVN屏蔽文件实现方式

在命令行中,svn 中不像 git 可以使用一个文件对仓库要屏蔽的文件进行管理,网上有很多这方面的命令教程:

  • SVN忽略文件或文件夹几种方法总结
  • linux下svn 增加 ignore 属性(忽略文件的处理)

但这并不是我想要的效果,所以我自己实现了一个简单的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

切记,此文件不能出现斜杠 / 字符!这也是一个不完善的地方,还请大神指点如何解决。

你可能感兴趣的:(SVN屏蔽文件实现方式)