递归地忽略SVN中的文件或目录模式而不全局忽略的最佳方法

问题描述

|| 很多时候,由于编译或打开项目文件而创建了临时文件。我希望SVN忽略这些文件的创建位置(而不是版本),而不必全局忽略它们,因为不同的程序/进程可能会在其他位置创建它们,并且它们可能需要版本控制(相同的扩展名是不同的文件类型)。使用Bash和SVN的最佳方法是什么?我创建的以下bash脚本是否足够?
# Recursively find,remove,and set svn:ignore on files or folders. 
# For safety,you must perform an svn status and an svn commit yourself.
#
# $1 is the pattern to ignore
# $2 is the starting directory (optional)
# $3 is a flag to remove the ignored files locally (optional)
#
# Example: recursive_svn_ignore \"*.bak\" . --remove
#
recursive_svn_ignore () 
{
    cd \"$2\";
    svn info > /dev/null 2>&1;
    if [ \"$?\" -ne \"0\" ]; then
      echo \"Skipping `pwd` because it is not under version control.\";
      return 1;
    fi;
    # Check if pattern matches
    ls -l $1 > /dev/null 2>&1;
    if [ \"$?\" = \"0\" ]; then
        for f in \"$1\"; do
            if [ \"$3\" = \"--remove\" ]; then
              # Remove file from working directory and repository 
              svn rm --force -q $f; 
            else
              # Remove file from repository only
              svn rm --force --keep-local $f;
            fi;
        done
        echo \"Adding \"$1\" in `pwd` to svn:ignore list\";
        svn propget svn:ignore . > svnignore.tempfile;
        echo \"$1\" >> svnignore.tempfile;
        svn propset -q svn:ignore -F svnignore.tempfile .;
        rm svnignore.tempfile;
    fi;
    # Recurse
    for d in *
    do
        if [ -d \"$d\" ]; then
            ( recursive_svn_ignore \"$1\" \"$d\" )
        fi;
    done
}
正如@ david-van-brink所建议的那样,使用
find
通过消除递归可以大大简化事情。这就是我想出的。
#!/bin/bash
# Recursively find and set svn:ignore on files or folders.
# If the file was already version it will be removed from the repository
# and keep the local copy (can be overridden).
# This does not perform the final commit so you can review the changes
# using svn status.
#
# $1 pattern to ignore
# $2 remove the ignored files locally as well (optional)
#
# Example: find_svn_ignore \"*.bak\" . --remove
#
for a in `find . -name $1`
do
        svn info ${a%/*} > /dev/null 2>&1;
        if [ \"$?\" -ne \"0\" ]; then
                echo \"Skipping ${a%/*} because it is not under version control.\";
                continue;
        fi;
        echo \"Ignoring ${a##*/} in ${a%/*}\";
        svn propget svn:ignore ${a%/*} > svnignore.tempfile;
        echo \"$1\" >> svnignore.tempfile;
        svn propset -q svn:ignore -F svnignore.tempfile ${a%/*};
        rm svnignore.tempfile;
        if [ \"$2\" = \"--remove\" ]; then
                # Remove file from working directory and repository 
                svn rm --force -q ${a##*/};
        else   
                # Remove file from repository only
                svn rm --force --keep-local ${a##*/};
        fi;
done
    

解决方法

使用\“ find \”可能更好。就像是:
for a in `find . -name \'*.bak\'`
 do
     echo something $a
     echo something else to $a
 done
或者将模式作为参数传递给函数。 用您的工作逻辑替换我的“ echo somethings”。它只是避免了实际的递归,以这种方式使用“ find”。 当然,实际上,您应该尽可能地调整流程以生成其他位置的文件,或者至少在一个\“ output \”文件夹中生成文件,以便整洁,因此您不必忽略不断增长的文件列表。 但是,是的,a,有些工具没有我们想要的那么整洁。     ,也许还有其他事情可以做。 为什么不简单地禁止将带有某些后缀的文件放入您的Subversion存储库? 我有一个挂钩脚本可以做到这一点。您给它提供一个glob模式或正则表达式,并且如果要使用与该glob模式或正则表达式相匹配的名称将文件添加到存储库中,则不会发生提交。开发人员将收到一条错误消息,并且必须先删除添加的文件,然后再提交。 这可以完成几件事: 开发人员将自己添加忽略模式。 他们将开始将构建的对象移动到其他目录 他们确保其构建脚本中的clean函数确实清除了编译创建的所有垃圾。 否则,您将不得不不断运行脚本。在生产线的某个地方,一些开发人员将检入他们不应该进行的检查,这将是您的错,因为您承担起了自己的职责,以防止发生这种情况。