mirror of
https://github.com/git/git.git
synced 2024-11-18 06:54:55 +01:00
Merge branch 'maint'
* maint: contrib/ciabot: Get ciabot configuration from git variables
This commit is contained in:
commit
7f6a0719da
2 changed files with 158 additions and 120 deletions
|
@ -11,43 +11,41 @@
|
||||||
#
|
#
|
||||||
# This script is meant to be run either in a post-commit hook or in an
|
# This script is meant to be run either in a post-commit hook or in an
|
||||||
# update hook. If there's nothing unusual about your hosting setup,
|
# update hook. If there's nothing unusual about your hosting setup,
|
||||||
# you can specify the project name with a -p option and avoid having
|
# you can specify the project name and repo with config variables and
|
||||||
# to modify this script. Try it with -n to see the notification mail
|
# avoid having to modify this script. Try it with -n to see the
|
||||||
# dumped to stdout and verify that it looks sane. With -V it dumps its
|
# notification mail dumped to stdout and verify that it looks
|
||||||
# version and exits.
|
# sane. With -V it dumps its version and exits.
|
||||||
#
|
#
|
||||||
# In post-commit, run it without arguments (other than possibly a -p
|
# In post-commit, run it without arguments. It will query for
|
||||||
# option). It will query for current HEAD and the latest commit ID to
|
# current HEAD and the latest commit ID to get the information it
|
||||||
# get the information it needs.
|
# needs.
|
||||||
#
|
#
|
||||||
# In update, call it with a refname followed by a list of commits:
|
# In update, call it with a refname followed by a list of commits:
|
||||||
# You want to reverse the order git rev-list emits becxause it lists
|
# You want to reverse the order git rev-list emits because it lists
|
||||||
# from most recent to oldest.
|
# from most recent to oldest.
|
||||||
#
|
#
|
||||||
# /path/to/ciabot.py ${refname} $(git rev-list ${oldhead}..${newhead} | tac)
|
# /path/to/ciabot.py ${refname} $(git rev-list ${oldhead}..${newhead} | tac)
|
||||||
#
|
#
|
||||||
# Note: this script uses mail, not XML-RPC, in order to avoid stalling
|
# Configuration variables affecting this script:
|
||||||
# until timeout when the CIA XML-RPC server is down.
|
# ciabot.project = name of the project (required)
|
||||||
|
# ciabot.repo = name of the project repo for gitweb/cgit purposes
|
||||||
|
# ciabot.xmlrpc = if true (default), ship notifications via XML-RPC
|
||||||
|
# ciabot.revformat = format in which the revision is shown
|
||||||
|
#
|
||||||
|
# The ciabot.repo value defaults to ciabot.project lowercased.
|
||||||
|
#
|
||||||
|
# The revformat variable may have the following values
|
||||||
|
# raw -> full hex ID of commit
|
||||||
|
# short -> first 12 chars of hex ID
|
||||||
|
# describe = -> describe relative to last tag, falling back to short
|
||||||
|
# The default is 'describe'.
|
||||||
|
#
|
||||||
|
# Note: the CIA project now says only XML-RPC is reliable, so
|
||||||
|
# we default to that.
|
||||||
#
|
#
|
||||||
|
|
||||||
#
|
|
||||||
# The project as known to CIA. You will either want to change this
|
|
||||||
# or invoke the script with a -p option to set it.
|
|
||||||
#
|
|
||||||
project=None
|
|
||||||
|
|
||||||
#
|
|
||||||
# You may not need to change these:
|
|
||||||
#
|
|
||||||
import os, sys, commands, socket, urllib
|
import os, sys, commands, socket, urllib
|
||||||
|
from xml.sax.saxutils import escape
|
||||||
# Name of the repository.
|
|
||||||
# You can hardwire this to make the script faster.
|
|
||||||
repo = os.path.basename(os.getcwd())
|
|
||||||
|
|
||||||
# Fully-qualified domain name of this host.
|
|
||||||
# You can hardwire this to make the script faster.
|
|
||||||
host = socket.getfqdn()
|
|
||||||
|
|
||||||
# Changeset URL prefix for your repo: when the commit ID is appended
|
# Changeset URL prefix for your repo: when the commit ID is appended
|
||||||
# to this, it should point at a CGI that will display the commit
|
# to this, it should point at a CGI that will display the commit
|
||||||
|
@ -72,7 +70,7 @@
|
||||||
<message>
|
<message>
|
||||||
<generator>
|
<generator>
|
||||||
<name>CIA Python client for Git</name>
|
<name>CIA Python client for Git</name>
|
||||||
<version>%(gitver)s</version>
|
<version>%(version)s</version>
|
||||||
<url>%(generator)s</url>
|
<url>%(generator)s</url>
|
||||||
</generator>
|
</generator>
|
||||||
<source>
|
<source>
|
||||||
|
@ -98,19 +96,18 @@
|
||||||
# No user-serviceable parts below this line:
|
# No user-serviceable parts below this line:
|
||||||
#
|
#
|
||||||
|
|
||||||
# Addresses for the e-mail. The from address is a dummy, since CIA
|
# Where to ship e-mail notifications.
|
||||||
# will never reply to this mail.
|
toaddr = "cia@cia.vc"
|
||||||
fromaddr = "CIABOT-NOREPLY@" + host
|
|
||||||
toaddr = "cia@cia.navi.cx"
|
|
||||||
|
|
||||||
# Identify the generator script.
|
# Identify the generator script.
|
||||||
# Should only change when the script itself gets a new home and maintainer.
|
# Should only change when the script itself gets a new home and maintainer.
|
||||||
generator="http://www.catb.org/~esr/ciabot.py"
|
generator = "http://www.catb.org/~esr/ciabot.py"
|
||||||
|
version = "3.5"
|
||||||
|
|
||||||
def do(command):
|
def do(command):
|
||||||
return commands.getstatusoutput(command)[1]
|
return commands.getstatusoutput(command)[1]
|
||||||
|
|
||||||
def report(refname, merged):
|
def report(refname, merged, xmlrpc=True):
|
||||||
"Generate a commit notification to be reported to CIA"
|
"Generate a commit notification to be reported to CIA"
|
||||||
|
|
||||||
# Try to tinyfy a reference to a web view for this commit.
|
# Try to tinyfy a reference to a web view for this commit.
|
||||||
|
@ -121,32 +118,27 @@ def report(refname, merged):
|
||||||
|
|
||||||
branch = os.path.basename(refname)
|
branch = os.path.basename(refname)
|
||||||
|
|
||||||
# Compute a shortnane for the revision
|
# Compute a description for the revision
|
||||||
rev = do("git describe '"+ merged +"' 2>/dev/null") or merged[:12]
|
if revformat == 'raw':
|
||||||
|
rev = merged
|
||||||
|
elif revformat == 'short':
|
||||||
|
rev = ''
|
||||||
|
else: # revformat == 'describe'
|
||||||
|
rev = do("git describe %s 2>/dev/null" % merged)
|
||||||
|
if not rev:
|
||||||
|
rev = merged[:12]
|
||||||
|
|
||||||
# Extract the neta-information for the commit
|
# Extract the meta-information for the commit
|
||||||
rawcommit = do("git cat-file commit " + merged)
|
|
||||||
files=do("git diff-tree -r --name-only '"+ merged +"' | sed -e '1d' -e 's-.*-<file>&</file>-'")
|
files=do("git diff-tree -r --name-only '"+ merged +"' | sed -e '1d' -e 's-.*-<file>&</file>-'")
|
||||||
inheader = True
|
metainfo = do("git log -1 '--pretty=format:%an <%ae>%n%at%n%s' " + merged)
|
||||||
headers = {}
|
(author, ts, logmsg) = metainfo.split("\n")
|
||||||
logmsg = ""
|
logmsg = escape(logmsg)
|
||||||
for line in rawcommit.split("\n"):
|
|
||||||
if inheader:
|
|
||||||
if line:
|
|
||||||
fields = line.split()
|
|
||||||
headers[fields[0]] = " ".join(fields[1:])
|
|
||||||
else:
|
|
||||||
inheader = False
|
|
||||||
else:
|
|
||||||
logmsg = line
|
|
||||||
break
|
|
||||||
(author, ts) = headers["author"].split(">")
|
|
||||||
|
|
||||||
# This discards the part of the authors addrsss after @.
|
# This discards the part of the author's address after @.
|
||||||
# Might be bnicece to ship the full email address, if not
|
# Might be be nice to ship the full email address, if not
|
||||||
# for spammers' address harvesters - getting this wrong
|
# for spammers' address harvesters - getting this wrong
|
||||||
# would make the freenode #commits channel into harvester heaven.
|
# would make the freenode #commits channel into harvester heaven.
|
||||||
author = author.replace("<", "").split("@")[0].split()[-1]
|
author = escape(author.replace("<", "").split("@")[0].split()[-1])
|
||||||
|
|
||||||
# This ignores the timezone. Not clear what to do with it...
|
# This ignores the timezone. Not clear what to do with it...
|
||||||
ts = ts.strip().split()[0]
|
ts = ts.strip().split()[0]
|
||||||
|
@ -155,8 +147,7 @@ def report(refname, merged):
|
||||||
context.update(globals())
|
context.update(globals())
|
||||||
|
|
||||||
out = xml % context
|
out = xml % context
|
||||||
|
mail = '''\
|
||||||
message = '''\
|
|
||||||
Message-ID: <%(merged)s.%(author)s@%(project)s>
|
Message-ID: <%(merged)s.%(author)s@%(project)s>
|
||||||
From: %(fromaddr)s
|
From: %(fromaddr)s
|
||||||
To: %(toaddr)s
|
To: %(toaddr)s
|
||||||
|
@ -165,25 +156,40 @@ def report(refname, merged):
|
||||||
|
|
||||||
%(out)s''' % locals()
|
%(out)s''' % locals()
|
||||||
|
|
||||||
return message
|
if xmlrpc:
|
||||||
|
return out
|
||||||
|
else:
|
||||||
|
return mail
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
import getopt
|
import getopt
|
||||||
|
|
||||||
|
# Get all config variables
|
||||||
|
revformat = do("git config --get ciabot.revformat")
|
||||||
|
project = do("git config --get ciabot.project")
|
||||||
|
repo = do("git config --get ciabot.repo")
|
||||||
|
xmlrpc = do("git config --get ciabot.xmlrpc")
|
||||||
|
xmlrpc = not (xmlrpc and xmlrpc == "false")
|
||||||
|
|
||||||
|
host = socket.getfqdn()
|
||||||
|
fromaddr = "CIABOT-NOREPLY@" + host
|
||||||
|
|
||||||
try:
|
try:
|
||||||
(options, arguments) = getopt.getopt(sys.argv[1:], "np:V")
|
(options, arguments) = getopt.getopt(sys.argv[1:], "np:xV")
|
||||||
except getopt.GetoptError, msg:
|
except getopt.GetoptError, msg:
|
||||||
print "ciabot.py: " + str(msg)
|
print "ciabot.py: " + str(msg)
|
||||||
raise SystemExit, 1
|
raise SystemExit, 1
|
||||||
|
|
||||||
mailit = True
|
notify = True
|
||||||
for (switch, val) in options:
|
for (switch, val) in options:
|
||||||
if switch == '-p':
|
if switch == '-p':
|
||||||
project = val
|
project = val
|
||||||
elif switch == '-n':
|
elif switch == '-n':
|
||||||
mailit = False
|
notify = False
|
||||||
|
elif switch == '-x':
|
||||||
|
xmlrpc = True
|
||||||
elif switch == '-V':
|
elif switch == '-V':
|
||||||
print "ciabot.py: version 3.2"
|
print "ciabot.py: version", version
|
||||||
sys.exit(0)
|
sys.exit(0)
|
||||||
|
|
||||||
# Cough and die if user has not specified a project
|
# Cough and die if user has not specified a project
|
||||||
|
@ -191,8 +197,8 @@ def report(refname, merged):
|
||||||
sys.stderr.write("ciabot.py: no project specified, bailing out.\n")
|
sys.stderr.write("ciabot.py: no project specified, bailing out.\n")
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
# We'll need the git version number.
|
if not repo:
|
||||||
gitver = do("git --version").split()[0]
|
repo = project.lower()
|
||||||
|
|
||||||
urlprefix = urlprefix % globals()
|
urlprefix = urlprefix % globals()
|
||||||
|
|
||||||
|
@ -205,18 +211,29 @@ def report(refname, merged):
|
||||||
refname = arguments[0]
|
refname = arguments[0]
|
||||||
merges = arguments[1:]
|
merges = arguments[1:]
|
||||||
|
|
||||||
if mailit:
|
if notify:
|
||||||
|
if xmlrpc:
|
||||||
|
import xmlrpclib
|
||||||
|
server = xmlrpclib.Server('http://cia.vc/RPC2');
|
||||||
|
else:
|
||||||
import smtplib
|
import smtplib
|
||||||
server = smtplib.SMTP('localhost')
|
server = smtplib.SMTP('localhost')
|
||||||
|
|
||||||
for merged in merges:
|
for merged in merges:
|
||||||
message = report(refname, merged)
|
message = report(refname, merged, xmlrpc)
|
||||||
if mailit:
|
if not notify:
|
||||||
server.sendmail(fromaddr, [toaddr], message)
|
|
||||||
else:
|
|
||||||
print message
|
print message
|
||||||
|
elif xmlrpc:
|
||||||
|
try:
|
||||||
|
# RPC server is flaky, this can fail due to timeout.
|
||||||
|
server.hub.deliver(message)
|
||||||
|
except socket.error, e:
|
||||||
|
sys.stderr.write("%s\n" % e)
|
||||||
|
else:
|
||||||
|
server.sendmail(fromaddr, [toaddr], message)
|
||||||
|
|
||||||
if mailit:
|
if notify:
|
||||||
|
if not xmlrpc:
|
||||||
server.quit()
|
server.quit()
|
||||||
|
|
||||||
#End
|
#End
|
||||||
|
|
|
@ -3,6 +3,8 @@
|
||||||
# Copyright (c) 2006 Fernando J. Pereda <ferdy@gentoo.org>
|
# Copyright (c) 2006 Fernando J. Pereda <ferdy@gentoo.org>
|
||||||
# Copyright (c) 2008 Natanael Copa <natanael.copa@gmail.com>
|
# Copyright (c) 2008 Natanael Copa <natanael.copa@gmail.com>
|
||||||
# Copyright (c) 2010 Eric S. Raymond <esr@thyrsus.com>
|
# Copyright (c) 2010 Eric S. Raymond <esr@thyrsus.com>
|
||||||
|
# Assistance and review by Petr Baudis, author of ciabot.pl,
|
||||||
|
# is gratefully acknowledged.
|
||||||
#
|
#
|
||||||
# This is a version 3.x of ciabot.sh; use -V to find the exact
|
# This is a version 3.x of ciabot.sh; use -V to find the exact
|
||||||
# version. Versions 1 and 2 were shipped in 2006 and 2008 and are not
|
# version. Versions 1 and 2 were shipped in 2006 and 2008 and are not
|
||||||
|
@ -11,6 +13,7 @@
|
||||||
# Note: This script should be considered obsolete.
|
# Note: This script should be considered obsolete.
|
||||||
# There is a faster, better-documented rewrite in Python: find it as ciabot.py
|
# There is a faster, better-documented rewrite in Python: find it as ciabot.py
|
||||||
# Use this only if your hosting site forbids Python hooks.
|
# Use this only if your hosting site forbids Python hooks.
|
||||||
|
# It requires: git(1), hostname(1), cut(1), sendmail(1), and wget(1).
|
||||||
#
|
#
|
||||||
# Originally based on Git ciabot.pl by Petr Baudis.
|
# Originally based on Git ciabot.pl by Petr Baudis.
|
||||||
# This script contains porcelain and porcelain byproducts.
|
# This script contains porcelain and porcelain byproducts.
|
||||||
|
@ -19,14 +22,14 @@
|
||||||
#
|
#
|
||||||
# This script is meant to be run either in a post-commit hook or in an
|
# This script is meant to be run either in a post-commit hook or in an
|
||||||
# update hook. If there's nothing unusual about your hosting setup,
|
# update hook. If there's nothing unusual about your hosting setup,
|
||||||
# you can specify the project name with a -p option and avoid having
|
# you can specify the project name and repo with config variables and
|
||||||
# to modify this script. Try it with -n first to see the notification
|
# avoid having to modify this script. Try it with -n to see the
|
||||||
# mail dumped to stdout and verify that it looks sane. Use -V to dump
|
# notification mail dumped to stdout and verify that it looks
|
||||||
# the version and exit.
|
# sane. With -V it dumps its version and exits.
|
||||||
#
|
#
|
||||||
# In post-commit, run it without arguments (other than possibly a -p
|
# In post-commit, run it without arguments. It will query for
|
||||||
# option). It will query for current HEAD and the latest commit ID to
|
# current HEAD and the latest commit ID to get the information it
|
||||||
# get the information it needs.
|
# needs.
|
||||||
#
|
#
|
||||||
# In update, you have to call it once per merged commit:
|
# In update, you have to call it once per merged commit:
|
||||||
#
|
#
|
||||||
|
@ -34,33 +37,54 @@
|
||||||
# oldhead=$2
|
# oldhead=$2
|
||||||
# newhead=$3
|
# newhead=$3
|
||||||
# for merged in $(git rev-list ${oldhead}..${newhead} | tac) ; do
|
# for merged in $(git rev-list ${oldhead}..${newhead} | tac) ; do
|
||||||
# /path/to/ciabot.bash ${refname} ${merged}
|
# /path/to/ciabot.sh ${refname} ${merged}
|
||||||
# done
|
# done
|
||||||
#
|
#
|
||||||
# The reason for the tac call ids that git rev-list emits commits from
|
# The reason for the tac call is that git rev-list emits commits from
|
||||||
# most recent to least - better to ship notifactions from oldest to newest.
|
# most recent to least - better to ship notifactions from oldest to newest.
|
||||||
#
|
#
|
||||||
# Note: this script uses mail, not XML-RPC, in order to avoid stalling
|
# Configuration variables affecting this script:
|
||||||
# until timeout when the CIA XML-RPC server is down.
|
# ciabot.project = name of the project (makes -p option unnecessary)
|
||||||
|
# ciabot.repo = name of the project repo for gitweb/cgit purposes
|
||||||
|
# ciabot.revformat = format in which the revision is shown
|
||||||
|
#
|
||||||
|
# The ciabot.repo defaults to ciabot.project lowercased.
|
||||||
|
#
|
||||||
|
# The revformat variable may have the following values
|
||||||
|
# raw -> full hex ID of commit
|
||||||
|
# short -> first 12 chars of hex ID
|
||||||
|
# describe = -> describe relative to last tag, falling back to short
|
||||||
|
# The default is 'describe'.
|
||||||
|
#
|
||||||
|
# Note: the shell ancestors of this script used mail, not XML-RPC, in
|
||||||
|
# order to avoid stalling until timeout when the CIA XML-RPC server is
|
||||||
|
# down. It is unknown whether this is still an issue in 2010, but
|
||||||
|
# XML-RPC would be annoying to do from sh in any case. (XML-RPC does
|
||||||
|
# have the advantage that it guarantees notification of multiple commits
|
||||||
|
# shpped from an update in their actual order.)
|
||||||
#
|
#
|
||||||
|
|
||||||
#
|
# The project as known to CIA. You can also hardwire this or set it with a
|
||||||
# The project as known to CIA. You will either want to change this
|
# -p option.
|
||||||
# or set the project name with a -p option.
|
project=$(git config --get ciabot.project)
|
||||||
#
|
|
||||||
project=
|
|
||||||
|
|
||||||
#
|
# Name of the repo for gitweb/cgit purposes
|
||||||
# You may not need to change these:
|
repo=$(git config --get ciabot.repo)
|
||||||
#
|
[ -z $repo] && repo=$(echo "${project}" | tr '[A-Z]' '[a-z]')
|
||||||
|
|
||||||
# Name of the repository.
|
# What revision format do we want in the summary?
|
||||||
# You can hardwire this to make the script faster.
|
revformat=$(git config --get ciabot.revformat)
|
||||||
repo="`basename ${PWD}`"
|
|
||||||
|
|
||||||
# Fully qualified domain name of the repo host.
|
# Fully qualified domain name of the repo host. You can hardwire this
|
||||||
# You can hardwire this to make the script faster.
|
# to make the script faster. The -f option works under Linux and FreeBSD,
|
||||||
host=`hostname --fqdn`
|
# but not OpenBSD and NetBSD. But under OpenBSD and NetBSD,
|
||||||
|
# hostname without options gives the FQDN.
|
||||||
|
if hostname -f >/dev/null 2>&1
|
||||||
|
then
|
||||||
|
hostname=`hostname -f`
|
||||||
|
else
|
||||||
|
hostname=`hostname`
|
||||||
|
fi
|
||||||
|
|
||||||
# Changeset URL prefix for your repo: when the commit ID is appended
|
# Changeset URL prefix for your repo: when the commit ID is appended
|
||||||
# to this, it should point at a CGI that will display the commit
|
# to this, it should point at a CGI that will display the commit
|
||||||
|
@ -73,13 +97,14 @@ urlprefix="http://${host}/cgi-bin/cgit.cgi/${repo}/commit/?id="
|
||||||
# You probably will not need to change the following:
|
# You probably will not need to change the following:
|
||||||
#
|
#
|
||||||
|
|
||||||
# Identify the script. Should change only when the script itself
|
# Identify the script. The 'generator' variable should change only
|
||||||
# gets a new home and maintainer.
|
# when the script itself gets a new home and maintainer.
|
||||||
generator="http://www.catb.org/~esr/ciabot/ciabot.sh"
|
generator="http://www.catb.org/~esr/ciabot/ciabot.sh"
|
||||||
|
version=3.4
|
||||||
|
|
||||||
# Addresses for the e-mail
|
# Addresses for the e-mail
|
||||||
from="CIABOT-NOREPLY@${host}"
|
from="CIABOT-NOREPLY@${hostname}"
|
||||||
to="cia@cia.navi.cx"
|
to="cia@cia.vc"
|
||||||
|
|
||||||
# SMTP client to use - may need to edit the absolute pathname for your system
|
# SMTP client to use - may need to edit the absolute pathname for your system
|
||||||
sendmail="sendmail -t -f ${from}"
|
sendmail="sendmail -t -f ${from}"
|
||||||
|
@ -97,7 +122,7 @@ do
|
||||||
case $opt in
|
case $opt in
|
||||||
p) project=$2; shift ; shift ;;
|
p) project=$2; shift ; shift ;;
|
||||||
n) mode=dumpit; shift ;;
|
n) mode=dumpit; shift ;;
|
||||||
V) echo "ciabot.sh: version 3.2"; exit 0; shift ;;
|
V) echo "ciabot.sh: version $version"; exit 0; shift ;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
|
@ -128,33 +153,29 @@ fi
|
||||||
|
|
||||||
refname=${refname##refs/heads/}
|
refname=${refname##refs/heads/}
|
||||||
|
|
||||||
gitver=$(git --version)
|
case $revformat in
|
||||||
gitver=${gitver##* }
|
raw) rev=$merged ;;
|
||||||
|
short) rev='' ;;
|
||||||
|
*) rev=$(git describe ${merged} 2>/dev/null) ;;
|
||||||
|
esac
|
||||||
|
[ -z ${rev} ] && rev=$(echo "$merged" | cut -c 1-12)
|
||||||
|
|
||||||
rev=$(git describe ${merged} 2>/dev/null)
|
# We discard the part of the author's address after @.
|
||||||
# ${merged:0:12} was the only bashism left in the 2008 version of this
|
|
||||||
# script, according to checkbashisms. Replace it with ${merged} here
|
|
||||||
# because it was just a fallback anyway, and it's worth accepting a
|
|
||||||
# longer fallback for faster execution and removing the bash
|
|
||||||
# dependency.
|
|
||||||
[ -z ${rev} ] && rev=${merged}
|
|
||||||
|
|
||||||
# This discards the part of the author's address after @.
|
|
||||||
# Might be nice to ship the full email address, if not
|
# Might be nice to ship the full email address, if not
|
||||||
# for spammers' address harvesters - getting this wrong
|
# for spammers' address harvesters - getting this wrong
|
||||||
# would make the freenode #commits channel into harvester heaven.
|
# would make the freenode #commits channel into harvester heaven.
|
||||||
rawcommit=$(git cat-file commit ${merged})
|
author=$(git log -1 '--pretty=format:%an <%ae>' $merged)
|
||||||
author=$(echo "$rawcommit" | sed -n -e '/^author .*<\([^@]*\).*$/s--\1-p')
|
author=$(echo "$author" | sed -n -e '/^.*<\([^@]*\).*$/s--\1-p')
|
||||||
logmessage=$(echo "$rawcommit" | sed -e '1,/^$/d' | head -n 1)
|
|
||||||
logmessage=$(echo "$logmessage" | sed 's/\&/&\;/g; s/</<\;/g; s/>/>\;/g')
|
logmessage=$(git log -1 '--pretty=format:%s' $merged)
|
||||||
ts=$(echo "$rawcommit" | sed -n -e '/^author .*> \([0-9]\+\).*$/s--\1-p')
|
ts=$(git log -1 '--pretty=format:%at' $merged)
|
||||||
files=$(git diff-tree -r --name-only ${merged} | sed -e '1d' -e 's-.*-<file>&</file>-')
|
files=$(git diff-tree -r --name-only ${merged} | sed -e '1d' -e 's-.*-<file>&</file>-')
|
||||||
|
|
||||||
out="
|
out="
|
||||||
<message>
|
<message>
|
||||||
<generator>
|
<generator>
|
||||||
<name>CIA Shell client for Git</name>
|
<name>CIA Shell client for Git</name>
|
||||||
<version>${gitver}</version>
|
<version>${version}</version>
|
||||||
<url>${generator}</url>
|
<url>${generator}</url>
|
||||||
</generator>
|
</generator>
|
||||||
<source>
|
<source>
|
||||||
|
|
Loading…
Reference in a new issue