Browse Source

enhance git2debcl to work with older python releases

pull/159/head
Antonio SJ Musumeci 9 years ago
parent
commit
5489952aa8
  1. 65
      tools/git2debcl

65
tools/git2debcl

@ -59,43 +59,76 @@ def guess_distribution():
try: try:
with open('/etc/lsb-release') as f: with open('/etc/lsb-release') as f:
return find_distrib_codename(f) return find_distrib_codename(f)
except:
try:
args = ['lsb_release','-c','-s']
return subprocess.check_output(args).strip()
except: except:
return 'unknown' return 'unknown'
parser = argparse.ArgumentParser(description='Generated debian/changelog from git log')
parser.add_argument('--name',type=str,help='Name of package',required=True)
parser.add_argument('--version',type=str,help='Place in git history to include upto',default='::guess::')
parser.add_argument('--distro',type=str,help='Distribution name',default='::guess::')
parser.add_argument('--urgency',type=str,help='Urgency',default='medium')
args = parser.parse_args()
if args.distro == '::guess::':
def patch_subprocess():
if "check_output" not in dir( subprocess ): # duck punch it in!
def check_output(*popenargs, **kwargs):
r"""Run command with arguments and return its output as a byte string.
Backported from Python 2.7 as it's implemented as pure python on stdlib.
>>> check_output(['/usr/bin/python', '--version'])
Python 2.6.2
"""
process = subprocess.Popen(stdout=subprocess.PIPE, *popenargs, **kwargs)
output, unused_err = process.communicate()
retcode = process.poll()
if retcode:
cmd = kwargs.get("args")
if cmd is None:
cmd = popenargs[0]
error = subprocess.CalledProcessError(retcode, cmd)
error.output = output
raise error
return output
subprocess.check_output = check_output
def main():
patch_subprocess()
parser = argparse.ArgumentParser(description='Generated debian/changelog from git log')
parser.add_argument('--name',type=str,help='Name of package',required=True)
parser.add_argument('--version',type=str,help='Place in git history to include upto',default='::guess::')
parser.add_argument('--distro',type=str,help='Distribution name',default='::guess::')
parser.add_argument('--urgency',type=str,help='Urgency',default='medium')
args = parser.parse_args()
if args.distro == '::guess::':
args.distro = guess_distribution() args.distro = guess_distribution()
if args.version == '::guess::':
if args.version == '::guess::':
args.version = git_version() args.version = git_version()
tags = git_tags()
tags = git_tags()
if args.version in tags:
if args.version in tags:
idx = tags.index(args.version) idx = tags.index(args.version)
tags = tags[idx:] tags = tags[idx:]
tags = zip(tags,tags) tags = zip(tags,tags)
else:
else:
tags = zip(tags,tags) tags = zip(tags,tags)
tags.insert(0,(args.version,'HEAD')) tags.insert(0,(args.version,'HEAD'))
tag = tags[0]
for prev in tags[1:]:
tag = tags[0]
for prev in tags[1:]:
print('%s (%s) %s; urgency=%s\n' % (args.name,tag[0],args.distro,args.urgency)) print('%s (%s) %s; urgency=%s\n' % (args.name,tag[0],args.distro,args.urgency))
lines = git_log(tag[1],prev[1]) lines = git_log(tag[1],prev[1])
for line in lines: for line in lines:
print " * " + line print " * " + line
print
authorandtime = git_author_and_time(tag[1]) authorandtime = git_author_and_time(tag[1])
print(' %s\n' % authorandtime) print(' %s\n' % authorandtime)
tag = prev tag = prev
if __name__ == "__main__":
main()
Loading…
Cancel
Save