mirror of
https://github.com/catchorg/Catch2.git
synced 2024-11-25 23:06:10 +01:00
Added ability for releaseNotes script to pull github issue titles
This commit is contained in:
parent
18845dab7f
commit
57374a1fab
@ -1,8 +1,13 @@
|
|||||||
import os
|
import os
|
||||||
|
import re
|
||||||
|
import urllib2
|
||||||
|
import json
|
||||||
|
|
||||||
from scriptCommon import catchPath
|
from scriptCommon import catchPath
|
||||||
from scriptCommon import runAndCapture
|
from scriptCommon import runAndCapture
|
||||||
|
|
||||||
|
issueNumberRe = re.compile( r'(.*?)#([0-9]*)([^0-9]?.*)' )
|
||||||
|
|
||||||
rootPath = os.path.join( catchPath, 'include/' )
|
rootPath = os.path.join( catchPath, 'include/' )
|
||||||
versionPath = os.path.join( rootPath, "internal/catch_version.hpp" )
|
versionPath = os.path.join( rootPath, "internal/catch_version.hpp" )
|
||||||
|
|
||||||
@ -13,6 +18,20 @@ lines = runAndCapture( ['git', 'log', hashes[1] + ".." + hashes[0], catchPath] )
|
|||||||
prevLine = ""
|
prevLine = ""
|
||||||
messages = []
|
messages = []
|
||||||
dates = []
|
dates = []
|
||||||
|
issues = {}
|
||||||
|
|
||||||
|
def getIssueTitle( issueNumber ):
|
||||||
|
try:
|
||||||
|
s = urllib2.urlopen("https://api.github.com/repos/philsquared/catch/issues/" + issueNumber ).read()
|
||||||
|
except e:
|
||||||
|
return "#HTTP Error#"
|
||||||
|
|
||||||
|
try:
|
||||||
|
j = json.loads( s )
|
||||||
|
return j["title"]
|
||||||
|
except e:
|
||||||
|
return "#JSON Error#"
|
||||||
|
|
||||||
for line in lines:
|
for line in lines:
|
||||||
if line.startswith( "commit"):
|
if line.startswith( "commit"):
|
||||||
pass
|
pass
|
||||||
@ -24,8 +43,18 @@ for line in lines:
|
|||||||
elif line == "" and prevLine == "":
|
elif line == "" and prevLine == "":
|
||||||
pass
|
pass
|
||||||
else:
|
else:
|
||||||
messages.append( line )
|
|
||||||
prevLine = line
|
prevLine = line
|
||||||
|
match = issueNumberRe.match( line )
|
||||||
|
line2 = ""
|
||||||
|
while match:
|
||||||
|
issueNumber = match.group(2)
|
||||||
|
issue = '#{0} ("{1}")'.format( issueNumber, getIssueTitle( issueNumber ) )
|
||||||
|
line2 = line2 + match.group(1) + issue
|
||||||
|
match = issueNumberRe.match( match.group(3) )
|
||||||
|
if line2 == "":
|
||||||
|
messages.append( line )
|
||||||
|
else:
|
||||||
|
messages.append( line2 )
|
||||||
|
|
||||||
print "All changes between {0} and {1}:\n".format( dates[-1], dates[0] )
|
print "All changes between {0} and {1}:\n".format( dates[-1], dates[0] )
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user