X-Git-Url: https://git.ralfj.de/auto-debuild.git/blobdiff_plain/f2827092df37a79178807b7d018e126ae2c9c6c2..5cac4926663767f8c5a994b26f15f7e8ba78b10d:/auto_debuild.py diff --git a/auto_debuild.py b/auto_debuild.py index 3844102..8149e58 100755 --- a/auto_debuild.py +++ b/auto_debuild.py @@ -141,21 +141,13 @@ def automakeRules(r, config): './configure --build=$$BUILD_TYPE '+ # do the escape manually here so we can use the variables (there's no user-controlled string in here anyway) '--prefix=/usr --includedir=/usr/include --mandir=/usr/share/man --infodir=/usr/share/info '+ '--libdir=/usr/lib/$$MULTIARCH --libexecdir=/usr/lib/$$MULTIARCH '+ - '--sysconfdir=/etc --localstatedir=/var '+ - safeCall(*config.get('automakeParameters', [])) + safeCall('--docdir=/usr/share/doc/'+config['binaryName'], '--sysconfdir=/etc', '--localstatedir=/var', *config.get('automakeParameters', [])) ] r.rules['auto_clean'] = ['rm -f config.status'] # do not re-use old configuration (no need for escaping here, obviously) -def pythonRules(r, config): - r.dh += ["--buildsystem=python_distutils"] - r.dhWith.add('python2') - r.rules['auto_clean'] = [ # clean properly - 'dh_auto_clean', - 'rm -rf build' - ] - def makefileRules(r, config): r.dh += ["--buildsystem=makefile"] + r.rules['auto_configure'] = [] def noneRules(r, config): r.dh += ["--buildsystem=makefile"] # makefile does the least possible harm @@ -168,7 +160,6 @@ def noneRules(r, config): buildSystems = { 'cmake': BuildSystem(cmakeRules, ["cmake"]), 'automake': BuildSystem(automakeRules), - 'python': BuildSystem(pythonRules, ["python-setuptools"], ["${python:Depends}"]), 'makefile': BuildSystem(makefileRules), 'none': BuildSystem(noneRules), } @@ -196,6 +187,7 @@ def createDebianFiles(config): config = ConfigDict(config) sourceName = config.getstr('sourceName') binaryName = config.getstr('binaryName', sourceName+'-local') + config['binaryName'] = binaryName # make it usable by build systems name = config.getstr('name', os.getenv('USER')) # os.getlogin() fails in minimal chroots email = config.getstr('email', os.getenv('USER')+'@'+os.uname()[1]) # user@hostname debDir = os.path.expanduser(config.getstr('debDir')) @@ -206,8 +198,18 @@ def createDebianFiles(config): parallelJobs = config.getint('parallelJobs', 2) packageArchitecture = config.getstr('architecture', 'any') withPython2 = config.getbool('withPython2', False) + withSIP = config.getbool('withSIP', False) + withAutoreconf = config.getbool('withAutoreconf', False) + # add some build dependencies (a bit hacky adding it to the build system...) + if withSIP: + withPython2 = True + buildSystem.buildDepends.append("python-sip") + buildSystem.binaryDepends.append("${sip:Depends}") if withPython2: - buildSystem.binaryDepends.append("${python:Depends}") # HACK, but it works: make sure dependencies on binary are added + buildSystem.buildDepends.append("python") + buildSystem.binaryDepends.append("${python:Depends}") + if withAutoreconf: + buildSystem.buildDepends.append("dh-autoreconf") # we return the list of files generated, so we need to know the architecture arch = getArchitecture(config) files = [] @@ -318,6 +320,7 @@ def createDebianFiles(config): r = RulesFile() r.rules['auto_test'] = [] r.rules['auto_install'] = [safeCall('dh_auto_install', '--destdir=debian/'+binaryName)] # install everything into the binary package + r.rules['auto_configure'] = ['dh_auto_configure'] # make sure there is an override (we may just append to it later) # patch rule file for build system: may only touch auto_* rules and the dh options buildSystem.ruleMaker(r, config) # global rules @@ -329,11 +332,14 @@ def createDebianFiles(config): r.dh += ['--parallel'] if withPython2: r.dhWith.add('python2') - r.rules['python2'] = ['dh_python2 --no-guessing-versions'] + r.rules['python2'] = ['dh_python2 --no-guessing-versions --no-shebang-rewrite'] + if withSIP: + r.rules['python2'].append(safeCall('dh_sip', '-p'+binaryName)) + if withAutoreconf: + r.dhWith.add('autoreconf') r.rules['builddeb'] = [safeCall('dh_builddeb', "--destdir="+debDir)] # passing this gobally to dh results in weird problems (like stuff being installed there, and not in the package...) # installation rule if 'binarySkipFiles' in config: - if not 'auto_install' in r.rules: r.rules['auto_install'] = ['dh_auto_install'] # make sure there is an override r.rules['auto_install'].append(safeCall('cd', 'debian/'+binaryName) + " && " + safeCall('rm', *config.get('binarySkipFiles'))) # debug packages if dbgPackage: @@ -342,7 +348,6 @@ def createDebianFiles(config): r.rules['installdocs'] = [safeCall('dh_installdocs', '--link-doc='+binaryName)] # wait after configuration? if config.getbool('waitAfterConfig', False): - if not 'auto_configure' in r.rules: r.rules['auto_configure'] = ['dh_auto_configure'] # make sure there is an override r.rules['auto_configure'].append("@"+safeCall('read', '-p', 'Configuration done. Hit "Enter" to build the package. ', 'DUMMY_VAR')) # if we run in dash, we need to tell it which variable to use for the result... # dump it to a file r.write(f) @@ -367,7 +372,7 @@ if __name__ == "__main__": config = loadConfigFile('auto-debuild.conf') # generate debian files if os.path.exists('debian'): - if raw_input("A debian folder already exists, to you want to remove it (y/N)? ").lower() != "y": + if raw_input("A debian folder already exists, do you want to remove it (y/N)? ").lower() != "y": sys.exit(1) shutil.rmtree('debian') files = createDebianFiles(config)