def build(self, reconfigure=False): # reconfigure is ignored (we always do a reconfiguration)
# create auto-debuild configuration
+ versionName = self.config['versionName'] if 'versionName' in self.config else self.vcs.version()
autoDebuildConfig = {
'sourceName': self.config['name'],
'buildSystem': self.config['buildSystem'],
'name': self.config['debName'],
'email': self.config['debEMail'],
'parallelJobs': self.config['jobs'],
- 'version': self.vcs.version(),
+ 'version': versionName,
}
if autoDebuildConfig['version'] is None:
raise Exception("VCS did not provide us with a proper version number, please fix this")
if vcsName == 'git':
self.vcs = vcs.Git(self.sourceFolder(), config['url'], config['version'])
elif vcsName == 'svn':
- self.vcs = vcs.SVN(self.sourceFolder(), config['url'], config.get('versionName'))
+ self.vcs = vcs.SVN(self.sourceFolder(), config['url'])
else:
raise Exception("Unknown VCS type "+vcsName)
# build system
elif name in allFolders:
workProjects += allFolders[name]
else:
- raise Exception("Project or folder%s does not exist" % name)
+ raise Exception("Project or folder %s does not exist" % name)
elif args.resume_from is None:
workProjects = projects.values() # all the projects
else:
import os, git, subprocess
-'''A VCS must have an "update" method with an optional "forceVersion" parameter, and a "version" method.'''
+'''A VCS must have an "update" method with an optional "forceVersion" parameter, and optionally a "version" method.'''
# Fetch updates from git
class Git:
repo.head.reset(self.commit, working_tree=True)
else:
repo.git.rebase(self.commit)
+ # update submodules
+ repo.git.submodule("update", "--init", "--recursive", "--rebase")
+ # done
print "...done",
if repo.head.reference.commit != repo.commit(self.commit):
print "(keeping local patches around)",
# Fetch updates via SVN
class SVN:
- def __init__(self, folder, url, versionName):
+ def __init__(self, folder, url):
self.folder = os.path.abspath(folder)
self.url = url
- self.versionName = versionName
def update(self, forceVersion=False):
if os.path.exists(self.folder):
subprocess.check_call(['svn', 'switch', self.url]) # and update to the URL we got
else:
subprocess.check_call(['svn', 'co', self.url, self.folder]) # just download it
-
- def version(self):
- return self.versionName