如何在svn日志中显示特定用户的提交?

时间:2010-12-21 13:48:34

标签: svn bash version-control

如何在svn中显示特定用户的提交?我没有为svn log找到任何开关。

11 个答案:

答案 0 :(得分:252)

你可以用这个:

svn log | sed -n '/USERNAME/,/-----$/ p' 

它将显示指定用户(USERNAME)的每次提交。

<强>更新

根据@bahrep的建议,subversion 1.8附带--search选项。

答案 1 :(得分:93)

使用Subversion 1.8或更高版本:

svn log --search johnsmith77 -l 50

除了作者匹配之外,这也会在提交消息中显示包含该用户名的SVN提交,如果您的用户名不是常用词,则不会发生这种情况。

-l 50会将搜索范围限制为最新的50个条目。

  

--search ARG

     

过滤日志消息以仅显示与搜索模式ARG匹配的消息。

     

仅当提供的搜索模式与作者,日期,日志消息文本中的任何一个匹配时(除非使用--quiet),或者如果还提供了--verbose选项,则仅显示日志消息,改变了路径。

     

如果提供了多个--search选项,则会显示与任何提供的搜索模式匹配的日志消息。

     

如果使用--limit,则会限制搜索的日志消息数,而不是将输出限制为特定数量的匹配日志消息。

http://svnbook.red-bean.com/en/1.8/svn.ref.svn.html#svn.ref.svn.sw.search

答案 2 :(得分:17)

svn没有附带内置选项。它有一个svn log --xml选项,允许您自己解析输出,并获得有趣的部分。

您可以编写一个脚本来解析它,例如,在Python 2.6中:

import sys
from xml.etree.ElementTree import iterparse, dump

author = sys.argv[1]
iparse = iterparse(sys.stdin, ['start', 'end'])

for event, elem in iparse:
    if event == 'start' and elem.tag == 'log':
        logNode = elem
        break

logentries = (elem for event, elem in iparse
                   if event == 'end' and elem.tag == 'logentry')

for logentry in logentries:
    if logentry.find('author').text == author:
        dump(logentry)
    logNode.remove(logentry)

如果将上述内容保存为svnLogStripByAuthor.py,则可将其命名为:

svn log --xml other-options | svnLogStripByAuthor.py user

答案 3 :(得分:13)

因为每个人似乎都倾向于使用linux(等):这是Windows的等价物:

svn log [SVNPath]|find "USERNAME"

答案 4 :(得分:8)

svn log | grep user

大部分都有效。

或者更准确:

svn log | egrep 'r[0-9]+ \| user \|'

答案 5 :(得分:5)

虽然yvoyer的解决方案工作正常,但这里有一个利用SVN的XML输出,用xmlstarlet解析它。

svn log --xml | xmlstarlet sel -t -m 'log/logentry' \
  --if "author = '<AUTHOR>'" \
  -v "concat('Revision ', @revision, ' ', date)" -n -v msg -n -n

从这里开始,您可以进入更高级的XML查询。

答案 6 :(得分:3)

这是我使用xslt的解决方案。不幸的是,xsltproc不是流处理器,所以你必须给日志一个限制。用法示例:

svn log -v --xml --limit=500  | xsltproc --stringparam author yonran /path/to/svnLogFilter.xslt  - | xsltproc /path/to/svnLogText.xslt  - | less

svnLogFilter.xslt

<!--
svnLogFilter.xslt

Usage: (note: use double dashes; I can't do double dashes in a XML comment)
svn log -xml | xsltproc -stringparam author yonran svnLogFilter.xslt -
-->
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
  <xsl:param name="author" select="''"/>
  <xsl:strip-space elements="log"/>
  <xsl:variable name="uppercase" select="'ABCDEFGHIJKLMNOPQRSTUVWXYZ'"/>
  <xsl:variable name="lowercase" select="'abcdefghijklmnopqrstuvwxyz'"/>
  <xsl:variable name="lowercaseAuthor" select="translate($author, $uppercase, $lowercase)"/>

<xsl:template match="/log">
  <xsl:copy>
    <xsl:apply-templates name="entrymatcher"/>
  </xsl:copy>
</xsl:template>

<xsl:template name="entrymatcher" match="logentry">
  <xsl:variable name="lowercaseChangeAuthor" select="translate(author, $uppercase, $lowercase)"/>
  <xsl:choose>
    <xsl:when test="contains($lowercaseChangeAuthor, $lowercaseAuthor)">
      <xsl:call-template name="insideentry"/>
    </xsl:when>
    <!--Filter out-->
    <xsl:otherwise/>
  </xsl:choose>
</xsl:template>


<xsl:template name="insideentry" match="@*|node()">
  <xsl:copy>
    <xsl:apply-templates select="@*|node()"/>
  </xsl:copy>
</xsl:template>

</xsl:stylesheet>

svnLogText.xslt

<!--
svnLogText.xslt

Usage: (note: use double dashes; I can't do double dashes in a XML comment)
svn log -xml -limit=1000 | xsltproc svnLogText.xslt -
-->
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
  <xsl:param name="author" select="''"/>
  <xsl:param name="xml" select="false()"/>
  <xsl:output method="text"/>

<xsl:template match="/log">
  <xsl:apply-templates name="entrymatcher"/>
  <xsl:text>------------------------------------------------------------------------&#xa;</xsl:text>
</xsl:template>

<xsl:template name="entrymatcher" match="logentry">
  <xsl:text>------------------------------------------------------------------------&#xa;</xsl:text>
  <xsl:text>r</xsl:text><xsl:value-of select="@revision"/>
  <xsl:text> | </xsl:text>
  <xsl:value-of select="author"/>
  <xsl:text> | </xsl:text>
  <xsl:value-of select="date"/>
  <xsl:text>&#xa;&#xa;</xsl:text>
  <xsl:if test="paths">
    <xsl:text>Changed paths:&#xa;</xsl:text>
    <xsl:for-each select="paths/path">
      <xsl:text>   </xsl:text>
      <xsl:value-of select="@action"/>
      <xsl:text> </xsl:text>
      <xsl:value-of select="."/>
      <xsl:text>&#xa;</xsl:text>
    </xsl:for-each>
  </xsl:if>
  <xsl:text>&#xa;</xsl:text>
  <xsl:value-of select="msg"/>
  <xsl:text>&#xa;</xsl:text>
</xsl:template>

</xsl:stylesheet>

答案 7 :(得分:3)

从Subversion 1.8开始,您可以使用--search and --search-and command-line options with svn log command

所以它应该像运行svn log --search JohnDoe一样简单。

答案 8 :(得分:1)

您可以使用Perl按用户名过滤日志,维护提交消息。只需设置$ /变量来决定Perl中构成“行”的内容。如果将其设置为SVN日志条目的分隔符,Perl将一次读取一条记录,然后您应该能够匹配整个记录中的用户名。见下文:

svn log | perl -ne 'BEGIN{$/="------------------------------------------------------------------------"} print if /USERNAME/'

答案 9 :(得分:1)

与签到一起获取差异。

将修订号编入文件:

svn log | sed -n '/USERNAME/,/-----$/ p'| grep "^r" 

现在阅读文件&amp;为每个修订执行diff:

while read p; do   svn log -v"$p" --diff ; done < Revisions.txt 

答案 10 :(得分:0)

我用Python编写了一个脚本:

#!/usr/bin/python
# coding:utf-8

import sys

argv_len = len(sys.argv)


def help():
    print 'Filter svnlog by user or date!       '
    print 'USEAGE: svnlog [ARGs]                '
    print 'ARGs:                                '
    print '    -n[=name]:                       '
    print '      filter by the special [=name]\n'
    print '    -t[=date]:                       '
    print '      filter by the special [=date]  '
    print 'EXP:                                 '
    print '1. Filter ruikye\'s commit log       \n'
    print '     svn log -l 50 | svnlog -n=ruikye\n'


if not argv_len - 1:
    help()
    quit()

author = ''
date = ''

for index in range(1, argv_len):
    argv = sys.argv[index]
    if argv.startswith('-n='):
        author = argv.replace('-n=', '')
    elif argv.startswith('-t='):
        date = argv.replace('-t=', '')
    else:
        help()
        quit()

if author == '' and date == '':
    help()
    quit()


SPLIT_LINE =
    '------------------------------------------------------------------------'
src = ''.join(sys.stdin.readlines()).replace('\n\n', '\n')
lines = src.split(SPLIT_LINE)

for line in lines:
    if author in line and date in line:
        print SPLIT_LINE, line

if len(lines):
    print SPLIT_LINE

并使用:

$ mv svnlog.py svnlog          

$ chmod a+x svnlog             

$ cd /usr/local/bin
$ ln -s ~/mycmd/svnlog filter 

$ svn log | filter -n=ruikye -t=2015-03-04