# Compile, build, and install cmake projects:
class CMake:
- def __init__(self, sourceFolder, buildFolder, projectConfig, globalConfig):
+ def __init__(self, sourceFolder, buildFolder, config):
self.sourceFolder = os.path.abspath(sourceFolder)
self.buildFolder = os.path.abspath(buildFolder)
- self.installDir = globalConfig['installDir']
- self.buildType = globalConfig['buildType']
- self.jobs = globalConfig['jobs']
- self.buildCmdPrefix = globalConfig['buildCmdPrefix']
- self.installCmdPrefix = globalConfig['installCmdPrefix']
- self.waitAfterConfig = globalConfig.get('waitAfterConfig', False)
- self.projectConfig = projectConfig
+ self.config = config
def build(self, reconfigure=False):
# Make sure we have a build directory
cacheFile = 'CMakeCache.txt'
if os.path.exists(cacheFile) and reconfigure: os.remove(cacheFile)
# Run cmake
- os.putenv('PKG_CONFIG_PATH', os.path.join(self.installDir, 'lib', 'pkgconfig')) # I found no way to do this within cmake
- subprocess.check_call(['cmake', self.sourceFolder, '-DCMAKE_BUILD_TYPE='+self.buildType,
- '-DCMAKE_INSTALL_PREFIX='+self.installDir]+self.projectConfig.get('cmakeParameters', []))
+ os.putenv('PKG_CONFIG_PATH', os.path.join(self.config['installDir'], 'lib', 'pkgconfig')) # I found no way to do this within cmake
+ subprocess.check_call(['cmake', self.sourceFolder, '-DCMAKE_BUILD_TYPE='+self.config['buildType'],
+ '-DCMAKE_INSTALL_PREFIX='+self.config['installDir']]+self.config.get('cmakeParameters', []))
os.unsetenv('PKG_CONFIG_PATH')
# if asked to do so, wait
- if self.waitAfterConfig:
+ if self.config['waitAfterConfig']:
raw_input('Configuration done. Hit "Enter" to build the project. ')
# run compilation
- subprocess.check_call(self.buildCmdPrefix + ['make', '-j'+str(self.jobs)])
+ subprocess.check_call(self.config['buildCmdPrefix'] + ['make', '-j'+str(self.config['jobs'])])
# run installation
- subprocess.check_call(self.installCmdPrefix + ['make', 'install'])
+ subprocess.check_call(self.config['installCmdPrefix'] + ['make', 'install'])
# if auto-debuild is available, provide a wrapper for it
try:
import auto_debuild
class AutoDebuild:
- def __init__(self, sourceFolder, buildFolder, projectConfig, vcs, globalConfig):
+ def __init__(self, sourceFolder, buildFolder, config, vcs):
self.sourceFolder = os.path.abspath(sourceFolder)
self.buildFolder = os.path.abspath(buildFolder)
- self.jobs = globalConfig['jobs']
- self.debDir = os.path.abspath(globalConfig['debDir'])
- self.debName = globalConfig['debName']
- self.debEMail = globalConfig['debEMail']
- self.waitAfterConfig = globalConfig.get('waitAfterConfig', False)
- self.projectConfig = projectConfig
+ self.debFolder = os.path.abspath(config['debDir'])
+ self.config = config
self.vcs = vcs
def build(self, reconfigure=False): # reconfigure is ignored (we always do a reconfiguration)
# create auto-debuild configuration
autoDebuildConfig = {
- 'sourceName': self.projectConfig['name'],
- 'buildSystem': self.projectConfig['buildSystem'],
- 'debDir': self.debDir,
+ 'sourceName': self.config['name'],
+ 'buildSystem': self.config['buildSystem'],
+ 'debDir': self.debFolder,
'buildDir': self.buildFolder,
- 'name': self.debName,
- 'email': self.debEMail,
- 'parallelJobs': self.jobs,
+ 'name': self.config['debName'],
+ 'email': self.config['debEMail'],
+ 'parallelJobs': self.config['jobs'],
'version': self.vcs.version(),
- 'waitAfterConfig': self.waitAfterConfig,
}
if autoDebuildConfig['version'] is None:
raise Exception("VCS did not provide us with a proper version number, please fix this")
# copy some more optional configuration
- for option in ('dbgPackage', 'section', 'withPython2', 'binarySkipFiles', 'binaryInstallFiles',
+ for option in ('waitAfterConfig', 'dbgPackage', 'section', 'withPython2', 'binarySkipFiles', 'binaryInstallFiles',
'buildDepends', 'binaryDepends', 'binaryRecommends', 'binaryProvides', 'binaryConflicts',
- 'cmakeParameters', 'automakeParameters'):
- if option in self.projectConfig:
- autoDebuildConfig[option] = self.projectConfig[option]
+ 'alternatives', 'cmakeParameters', 'automakeParameters'):
+ if option in self.config:
+ autoDebuildConfig[option] = self.config[option]
# create Debian files
os.chdir(self.sourceFolder)
if os.path.isdir('debian'): # clean previous build attempts
# build package(s)
auto_debuild.buildDebianPackage(autoDebuildConfig)
# install package(s)
- subprocess.check_call(['sudo', 'dpkg', '--install'] + files)
+ if self.config.get('debInstall', True):
+ subprocess.check_call(['sudo', 'dpkg', '--install'] + files)
except ImportError:
#print "auto_debuild not found, disabling auto-debuild system"
# an entire Project
class Project:
- def __init__(self, folder, projectConfig, globalConfig):
+ def __init__(self, folder, config):
self.folder = folder
- self.name = projectConfig['name']
+ self.name = config['name']
# VCS
- vcsName = projectConfig['vcs']
+ vcsName = config['vcs']
if vcsName == 'git':
- self.vcs = vcs.Git(self.sourceFolder(), projectConfig['url'], projectConfig['version'])
+ self.vcs = vcs.Git(self.sourceFolder(), config['url'], config['version'])
elif vcsName == 'svn':
- self.vcs = vcs.SVN(self.sourceFolder(), projectConfig['url'], projectConfig.get('versionName'))
+ self.vcs = vcs.SVN(self.sourceFolder(), config['url'], config.get('versionName'))
else:
raise Exception("Unknown VCS type "+vcsName)
# build system
- if globalConfig.get('buildDeb', False):
- self.buildSystem = build_system.AutoDebuild(self.sourceFolder(), self.buildFolder(), projectConfig, self.vcs, globalConfig)
+ if config.get('buildDeb', False):
+ self.buildSystem = build_system.AutoDebuild(self.sourceFolder(), self.buildFolder(), config, self.vcs)
else:
- buildSystemName = projectConfig['buildSystem']
+ buildSystemName = config['buildSystem']
if buildSystemName == 'cmake':
- self.buildSystem = build_system.CMake(self.sourceFolder(), self.buildFolder(), projectConfig, globalConfig)
+ self.buildSystem = build_system.CMake(self.sourceFolder(), self.buildFolder(), config)
else:
raise Exception("Unknown build system type "+buildSystemName)
return i
raise Exception("%s not found in list" % str(item))
+# copy all items which don't exist below, except for those in the exclude list
+def inherit(subConfig, superConfig, exclude = ('name', 'projects')):
+ for name in superConfig.keys():
+ if (not name in subConfig) and (not name in exclude):
+ subConfig[name] = superConfig[name]
+
# populate list of projects, return list of projects in that folder
-def loadProjects(projects, folder=''):
+def loadProjects(config, folder=''):
folderProjects = []
- for projectConfig in projects:
- if 'folder' in projectConfig: # a subpath
- folderProjects += loadProjects(projectConfig['projects'], os.path.join(folder, projectConfig['folder']))
+ for projectConfig in config['projects']:
+ assert 'name' in projectConfig # everything must have a name
+ inherit(projectConfig, config)
+ if 'projects' in projectConfig: # a subpath
+ folderProjects += loadProjects(projectConfig, os.path.join(folder, projectConfig['name']))
else: # a proper project
if projectConfig['name'] in allProjects:
- raise Exception("Duplicate project name "+project['name'])
- project = Project(folder, projectConfig, config)
+ raise Exception("Duplicate project name "+projectConfig['name'])
+ project = Project(folder, projectConfig)
allProjects[projectConfig['name']] = project
folderProjects.append(project)
# store projects of this folder
return folderProjects
# now check what we have to do
-loadProjects(config['projects'])
+loadProjects(config)
if args.projects:
if args.resume_from is not None:
raise Exception("Can not use --resume-from and manually specify projects")
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: