From: Ralf Jung Date: Sun, 29 Jul 2012 11:11:13 +0000 (+0200) Subject: add support for installing additional files X-Git-Url: https://git.ralfj.de/auto-debuild.git/commitdiff_plain/8b398829c3062f20c42b0a5d048cc3414098cc89 add support for installing additional files --- diff --git a/auto_debuild.py b/auto_debuild.py index 57ee13b..c274412 100755 --- a/auto_debuild.py +++ b/auto_debuild.py @@ -1,5 +1,5 @@ #!/usr/bin/python -import os, shutil, stat, time, subprocess, sys +import os, stat, time, subprocess, sys from collections import OrderedDict # some utility functions @@ -146,6 +146,10 @@ def createDebianFiles(config): print >>f, "Description:",sourceName,"debug smbols (auto-debuild)" print >>f, " Package containing debug symbols for "+sourceName+", auto-generated by auto-debuild." files.append(os.path.join(debDir, "%s-dbg_%s_%s.deb" % (binaryName, version, arch))) + # install file + with open('debian/'+binaryName+'.install', 'w') as f: + for line in config.get('binaryInstall', []): + print >>f, line # rules file: build system specific with open('debian/rules', 'w') as f: # get rule file for build system: may only touch auto_config and auto_clean rules and the dh options @@ -186,27 +190,26 @@ def buildDebianPackage(config): subprocess.check_call(commandInBuildEnv(config, command)) shutil.rmtree('debian') # it only contains what we just created -# all at once -def createAndInstall(config, overwriteCheck = False): +################################################################### +# if we are called directly as script +if __name__ == "__main__": + import imp, shutil + # get config + config = imp.load_source('config', 'auto-debuild.conf').__dict__ + os.remove('auto-debuild.confc') # 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": + sys.exit(1) + shutil.rmtree('debian') files = createDebianFiles(config) # check if a file is overwritten - if overwriteCheck: - for file in files: - if os.path.exists(file): - if raw_input("Do you want to overwrite %s (y/N)? " % file).lower() != "y": - sys.exit(1) + for file in files: + if os.path.exists(file): + if raw_input("Do you want to overwrite %s (y/N)? " % file).lower() != "y": + sys.exit(1) # run compilation buildDebianPackage(config) # install files print "Installing created deb files..." subprocess.check_call(['sudo', 'dpkg', '--install'] + files) - -# if we are called directly as script -if __name__ == "__main__": - # get config - import imp - config = imp.load_source('config', 'auto-debuild.conf').__dict__ - os.remove('auto-debuild.confc') - # and go for it - createAndInstall(config, overwriteCheck=True)