Make config inherited
authorRalf Jung <post@ralfj.de>
Wed, 15 Aug 2012 10:47:32 +0000 (12:47 +0200)
committerRalf Jung <post@ralfj.de>
Wed, 15 Aug 2012 10:47:32 +0000 (12:47 +0200)
build_system.py
mass_build.py

index 197d7ac08feb3d84b83cb8aab89d151fa5bb690f..8325aeda98c62e2ddaba9c1d6cc5e71ee0b1eb13 100644 (file)
@@ -4,16 +4,10 @@ import os, shutil, subprocess
 
 # 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
@@ -23,54 +17,49 @@ class CMake:
                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
@@ -79,7 +68,8 @@ try:
                        # 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"
index ed47bacbf21bb3bbe0b004d5a3da8e5ef7853034..6bbba4c23d8429e9b48c618ac6c94fbc73246cd1 100755 (executable)
@@ -5,24 +5,24 @@ from collections import OrderedDict
 
 # 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)
        
@@ -70,16 +70,24 @@ def findInList(list, item):
                        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
@@ -89,7 +97,7 @@ def loadProjects(projects, 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")
@@ -99,7 +107,7 @@ if args.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: