make setup.py more robust to possible errors during version string modification
This commit is contained in:
parent
09e0bf73c3
commit
0f73e89ec6
95
setup.py
95
setup.py
@ -1,6 +1,6 @@
|
|||||||
from distutils.core import setup
|
from distutils.core import setup
|
||||||
import distutils.dir_util
|
import distutils.dir_util
|
||||||
import os, re
|
import os, sys, re
|
||||||
from subprocess import check_output
|
from subprocess import check_output
|
||||||
|
|
||||||
## generate list of all sub-packages
|
## generate list of all sub-packages
|
||||||
@ -17,48 +17,57 @@ if os.path.isdir(buildPath):
|
|||||||
|
|
||||||
|
|
||||||
## Determine current version string
|
## Determine current version string
|
||||||
init = open(os.path.join(path, 'pyqtgraph', '__init__.py')).read()
|
initfile = os.path.join(path, 'pyqtgraph', '__init__.py')
|
||||||
|
init = open(initfile).read()
|
||||||
m = re.search(r'__version__ = (\S+)\n', init)
|
m = re.search(r'__version__ = (\S+)\n', init)
|
||||||
if m is None:
|
if m is None or len(m.groups()) != 1:
|
||||||
raise Exception("Cannot determine version number!")
|
raise Exception("Cannot determine __version__ from init file: '%s'!" % initfile)
|
||||||
version = m.group(1).strip('\'\"')
|
version = m.group(1).strip('\'\"')
|
||||||
initVersion = version
|
initVersion = version
|
||||||
|
|
||||||
# If this is a git checkout, append the current commit
|
# If this is a git checkout, try to generate a more decriptive version string
|
||||||
if os.path.isdir(os.path.join(path, '.git')):
|
try:
|
||||||
def gitCommit(name):
|
if os.path.isdir(os.path.join(path, '.git')):
|
||||||
commit = check_output(['git', 'show', name], universal_newlines=True).split('\n')[0]
|
def gitCommit(name):
|
||||||
assert commit[:7] == 'commit '
|
commit = check_output(['git', 'show', name], universal_newlines=True).split('\n')[0]
|
||||||
return commit[7:]
|
assert commit[:7] == 'commit '
|
||||||
|
return commit[7:]
|
||||||
# Find last tag matching "pyqtgraph-.*"
|
|
||||||
tagNames = check_output(['git', 'tag'], universal_newlines=True).strip().split('\n')
|
|
||||||
while True:
|
|
||||||
if len(tagNames) == 0:
|
|
||||||
raise Exception("Could not determine last tagged version.")
|
|
||||||
lastTagName = tagNames.pop()
|
|
||||||
if re.match(r'pyqtgraph-.*', lastTagName):
|
|
||||||
break
|
|
||||||
|
|
||||||
# is this commit an unchanged checkout of the last tagged version?
|
# Find last tag matching "pyqtgraph-.*"
|
||||||
lastTag = gitCommit(lastTagName)
|
tagNames = check_output(['git', 'tag'], universal_newlines=True).strip().split('\n')
|
||||||
head = gitCommit('HEAD')
|
while True:
|
||||||
if head != lastTag:
|
if len(tagNames) == 0:
|
||||||
branch = re.search(r'\* (.*)', check_output(['git', 'branch'])).group(1)
|
raise Exception("Could not determine last tagged version.")
|
||||||
version = version + "-%s-%s" % (branch, head[:10])
|
lastTagName = tagNames.pop()
|
||||||
|
if re.match(r'pyqtgraph-.*', lastTagName):
|
||||||
# any uncommitted modifications?
|
break
|
||||||
modified = False
|
|
||||||
status = check_output(['git', 'status', '-s'], universal_newlines=True).strip().split('\n')
|
# is this commit an unchanged checkout of the last tagged version?
|
||||||
for line in status:
|
lastTag = gitCommit(lastTagName)
|
||||||
if line[:2] != '??':
|
head = gitCommit('HEAD')
|
||||||
modified = True
|
if head != lastTag:
|
||||||
break
|
branch = re.search(r'\* (.*)', check_output(['git', 'branch'])).group(1)
|
||||||
|
version = version + "-%s-%s" % (branch, head[:10])
|
||||||
if modified:
|
|
||||||
version = version + '+'
|
# any uncommitted modifications?
|
||||||
|
modified = False
|
||||||
|
status = check_output(['git', 'status', '-s'], universal_newlines=True).strip().split('\n')
|
||||||
|
for line in status:
|
||||||
|
if line[:2] != '??':
|
||||||
|
modified = True
|
||||||
|
break
|
||||||
|
|
||||||
|
if modified:
|
||||||
|
version = version + '+'
|
||||||
|
sys.stderr.write("Detected git commit; will use version string: '%s'\n" % version)
|
||||||
|
except:
|
||||||
|
version = initVersion
|
||||||
|
sys.stderr.write("This appears to be a git checkout, but an error occurred "
|
||||||
|
"while attempting to determine a version string for the "
|
||||||
|
"current commit.\nUsing the unmodified version string "
|
||||||
|
"instead: '%s'\n" % version)
|
||||||
|
sys.excepthook(*sys.exc_info())
|
||||||
|
|
||||||
print("PyQtGraph version: " + version)
|
|
||||||
|
|
||||||
import distutils.command.build
|
import distutils.command.build
|
||||||
|
|
||||||
@ -73,8 +82,16 @@ class Build(distutils.command.build.build):
|
|||||||
return ret
|
return ret
|
||||||
|
|
||||||
initfile = os.path.join(path, self.build_lib, 'pyqtgraph', '__init__.py')
|
initfile = os.path.join(path, self.build_lib, 'pyqtgraph', '__init__.py')
|
||||||
data = open(initfile, 'r').read()
|
if not os.path.isfile(initfile):
|
||||||
open(initfile, 'w').write(re.sub(r"__version__ = .*", "__version__ = '%s'" % version, data))
|
sys.stderr.write("Warning: setup detected a git install and attempted "
|
||||||
|
"to generate a descriptive version string; however, "
|
||||||
|
"the expected build file at %s was not found. "
|
||||||
|
"Installation will use the original version string "
|
||||||
|
"%s instead.\n" % (initfile, initVersion)
|
||||||
|
)
|
||||||
|
else:
|
||||||
|
data = open(initfile, 'r').read()
|
||||||
|
open(initfile, 'w').write(re.sub(r"__version__ = .*", "__version__ = '%s'" % version, data))
|
||||||
return ret
|
return ret
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user