X-Git-Url: https://git.ralfj.de/mass-build.git/blobdiff_plain/515f24154b23ad4510e4ba1e1afbf8f6c1b6aab4..3a6b5ad415ec7aed415210d80107605149689e68:/build_system.py diff --git a/build_system.py b/build_system.py index 2e10aed..41061d3 100644 --- a/build_system.py +++ b/build_system.py @@ -1,4 +1,4 @@ -import os, subprocess +import os, shutil, subprocess '''A build system has three methods: "configure" (with optionak "force" parameter), "build" and "install"''' @@ -12,6 +12,7 @@ class CMake: self.jobs = config['jobs'] self.buildCmdPrefix = config['buildCmdPrefix'] self.installCmdPrefix = config['installCmdPrefix'] + self.waitAfterConfig = config.get('waitAfterConfig', False) self.module = module def build(self, reconfigure=False): @@ -26,6 +27,9 @@ class CMake: subprocess.check_call(['cmake', self.sourceFolder, '-DCMAKE_BUILD_TYPE='+self.buildType, '-DCMAKE_INSTALL_PREFIX='+self.installDir]+self.module.get('cmakeParameters', [])) os.unsetenv('PKG_CONFIG_PATH') + # if asked to do so, wait + if self.waitAfterConfig: + raw_input('Configuration done. Hit "Enter" to build the module. ') # run compilation subprocess.check_call(self.buildCmdPrefix + ['make', '-j'+str(self.jobs)]) # run installation @@ -42,6 +46,7 @@ try: self.debDir = os.path.abspath(config['debDir']) self.debName = config['debName'] self.debEMail = config['debEMail'] + self.waitAfterConfig = config.get('waitAfterConfig', False) self.module = module self.vcs = vcs @@ -49,23 +54,27 @@ try: # create auto-debuild configuration autoDebuildConfig = { 'sourceName': self.module['name'], - 'buildSystem': self.module['build-system'], + 'buildSystem': self.module['buildSystem'], 'debDir': self.debDir, 'buildDir': self.buildFolder, 'name': self.debName, 'email': self.debEMail, 'parallelJobs': self.jobs, - 'version': self.vcs.version() + 'version': self.vcs.version(), + 'waitAfterConfig': self.waitAfterConfig, } - if self.autoDebuildConfig['version'] is None: + 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', 'binarySkipFiles', 'binaryInstallFiles', 'buildDepends', 'binaryDepends', 'binaryRecommends', - 'binaryProvides', 'cmakeParameters', 'automakeParameters'): + for option in ('dbgPackage', 'section', 'binarySkipFiles', 'binaryInstallFiles', + 'buildDepends', 'binaryDepends', 'binaryRecommends', 'binaryProvides', + 'cmakeParameters', 'automakeParameters'): if option in self.module: autoDebuildConfig[option] = self.module[option] # create Debian files os.chdir(self.sourceFolder) + if os.path.isdir('debian'): # clean previous build attempts + shutil.rmtree('debian') files = auto_debuild.createDebianFiles(autoDebuildConfig) # build package(s) auto_debuild.buildDebianPackage(autoDebuildConfig) @@ -73,5 +82,5 @@ try: subprocess.check_call(['sudo', 'dpkg', '--install'] + files) except ImportError: - print "auto_debuild not found, disabling auto-debuild system" + #print "auto_debuild not found, disabling auto-debuild system" pass