From: Ralf Jung Date: Wed, 18 Jul 2012 13:23:57 +0000 (+0200) Subject: add support for automake-based programs X-Git-Url: https://git.ralfj.de/auto-debuild.git/commitdiff_plain/74e2c8497d6dacf9c01159ddc4b7618d1a593021?ds=inline;hp=6d5e051eaaff2fe4af1f2e2573284b706982857c add support for automake-based programs --- diff --git a/auto_debuild.py b/auto_debuild.py index 47102af..aa0b28f 100755 --- a/auto_debuild.py +++ b/auto_debuild.py @@ -2,6 +2,7 @@ import os, stat, time, subprocess, sys from collections import OrderedDict +# abstract representation of rules file class RulesFile: def __init__(self): self.env = [] @@ -19,12 +20,6 @@ class RulesFile: for line in self.rules[rule]: print >>f, "\t"+line -def getArchitecture(): - p = subprocess.Popen(['dpkg-architecture', '-qDEB_BUILD_ARCH'], stdout=subprocess.PIPE) - res = p.communicate()[0] # get only stdout - if p.returncode != 0: raise Exception("Querying dpkg for the architecture failed") - return res[0:len(res)-1] # chop of the \n at the end - # build-system specific part of rules file def cmakeRules(config): r = RulesFile() @@ -36,14 +31,32 @@ def cmakeRules(config): r.rules['auto_clean'] = ['rm -f build.dir/CMakeCache.txt'] # clean old cmake cache return r +def automakeRules(config): + r = RulesFile() + r.dh += ["--buildsystem=autoconf"] + r.rules['auto_configure'] = [ + './configure --build=$$(dpkg-architecture -qDEB_BUILD_GNU_TYPE) --prefix=/usr --sysconfdir=/etc --localstatedir=/var ' + + ' '.join(config.get('automakeParameters', [])) + ] + r.rules['auto_clean'] = ['rm -f config.status'] # do not re-use old configuration + return r + +# utility functions +def getArchitecture(): + p = subprocess.Popen(['dpkg-architecture', '-qDEB_BUILD_ARCH'], stdout=subprocess.PIPE) + res = p.communicate()[0] # get only stdout + if p.returncode != 0: raise Exception("Querying dpkg for the architecture failed") + return res[0:len(res)-1] # chop of the \n at the end + def writeDebList(list): return ', '.join(list) +# actual work functions def createDebianFiles(config): sourceName = config['sourceName'] binaryName = config.get('binaryName', sourceName+'-local') name = config.get('name', os.getlogin()) - email = config.get('email', os.getlogin()+'@'+os.uname()[1]) + email = config.get('email', os.getlogin()+'@'+os.uname()[1]) # user@hostname debDir = os.path.expanduser(config['debDir']) buildSystem = config['buildSystem'] version = config['version'] @@ -98,6 +111,8 @@ def createDebianFiles(config): # get rule file for build system: may only touch auto_config and auto_clean rules and the dh options if buildSystem == 'cmake': r = cmakeRules(config) + elif buildSystem == 'automake': + r = automakeRules(config) else: raise Exception("Invalid build system "+buildSystem) # global rules @@ -106,10 +121,10 @@ def createDebianFiles(config): r.dh += ['--parallel'] r.rules['builddeb'] = ['dh_builddeb --destdir='+debDir] # passing this gobally to dh results in weird problems (like stuff being installed there, and not in the package...) r.rules['auto_test'] = [] + r.rules['auto_install'] = ['dh_auto_install --destdir=debian/'+binaryName] # install everything into the binary package # for debug packages if dbgPackage: r.rules['strip'] = ['dh_strip --dbg-package='+binaryName+"-dbg"] - r.rules['auto_install'] = ['dh_auto_install --destdir=debian/'+binaryName] r.rules['installdocs'] = ['dh_installdocs --link-doc='+binaryName] # dump it to a file r.write(f)