Implement arch override.

Using the --arch option, it is possible to run depsolving
(Gather stage) on any host regardless the architecture.
This commit is contained in:
Daniel Mach 2011-11-01 14:08:15 -04:00 committed by Dennis Gilmore
parent 83a22bd5ea
commit 1623bbe936

View File

@ -85,6 +85,8 @@ def main():
config.set('pungi', 'nohash', "True") config.set('pungi', 'nohash', "True")
if opts.full_archlist: if opts.full_archlist:
config.set('pungi', 'full_archlist', "True") config.set('pungi', 'full_archlist', "True")
if opts.arch:
config.set('pungi', 'arch', opts.arch)
# Actually do work. # Actually do work.
mypungi = pypungi.Pungi(config, ksparser) mypungi = pypungi.Pungi(config, ksparser)
@ -218,6 +220,8 @@ if __name__ == '__main__':
help='disable hashing the Packages trees') help='disable hashing the Packages trees')
parser.add_option("--full-archlist", action="store_true", parser.add_option("--full-archlist", action="store_true",
help='Use the full arch list for x86_64 (include i686, i386, etc.)') help='Use the full arch list for x86_64 (include i686, i386, etc.)')
parser.add_option("--arch",
help='Override default (uname based) arch')
parser.add_option("-c", "--config", dest="config", parser.add_option("-c", "--config", dest="config",
help='Path to kickstart config file') help='Path to kickstart config file')
@ -245,6 +249,10 @@ if __name__ == '__main__':
if opts.do_gather or opts.do_createrepo or opts.do_buildinstall or opts.do_createiso: if opts.do_gather or opts.do_createrepo or opts.do_buildinstall or opts.do_createiso:
opts.do_all = False opts.do_all = False
if opts.arch and (opts.do_all or opts.do_buildinstall):
parser.error("cannot override arch while the BuildInstall stage is enabled")
return (opts, args) return (opts, args)
main() main()