mirror of
https://git.yoctoproject.org/poky
synced 2026-06-01 00:59:48 +00:00
wic: Clean up Creator
wic doesn't use a lot of Creator, so remove it. (From OE-Core rev: ef6bc7a3b58ba8b9c94f4c1e41c0f6d7d51c0bf5) Signed-off-by: Tom Zanussi <tom.zanussi@linux.intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
committed by
Richard Purdie
parent
f12336aa4a
commit
8678a6eb02
+6
-170
@@ -44,7 +44,7 @@ class Creator(cmdln.Cmdln):
|
|||||||
# mix-in do_subcmd interface
|
# mix-in do_subcmd interface
|
||||||
for subcmd, klass in pluginmgr.get_plugins('imager').iteritems():
|
for subcmd, klass in pluginmgr.get_plugins('imager').iteritems():
|
||||||
if not hasattr(klass, 'do_create'):
|
if not hasattr(klass, 'do_create'):
|
||||||
msger.warning("Unsurpport subcmd: %s" % subcmd)
|
msger.warning("Unsupported subcmd: %s" % subcmd)
|
||||||
continue
|
continue
|
||||||
|
|
||||||
func = getattr(klass, 'do_create')
|
func = getattr(klass, 'do_create')
|
||||||
@@ -65,59 +65,12 @@ class Creator(cmdln.Cmdln):
|
|||||||
optparser.add_option('-c', '--config', type='string', dest='config',
|
optparser.add_option('-c', '--config', type='string', dest='config',
|
||||||
default=None,
|
default=None,
|
||||||
help='Specify config file for mic')
|
help='Specify config file for mic')
|
||||||
optparser.add_option('-k', '--cachedir', type='string', action='store',
|
|
||||||
dest='cachedir', default=None,
|
|
||||||
help='Cache directory to store the downloaded')
|
|
||||||
optparser.add_option('-o', '--outdir', type='string', action='store',
|
optparser.add_option('-o', '--outdir', type='string', action='store',
|
||||||
dest='outdir', default=None,
|
dest='outdir', default=None,
|
||||||
help='Output directory')
|
help='Output directory')
|
||||||
optparser.add_option('-A', '--arch', type='string', dest='arch',
|
|
||||||
default=None,
|
|
||||||
help='Specify repo architecture')
|
|
||||||
optparser.add_option('', '--release', type='string', dest='release',
|
|
||||||
default=None, metavar='RID',
|
|
||||||
help='Generate a release of RID with all necessary'
|
|
||||||
' files, when @BUILD_ID@ is contained in '
|
|
||||||
'kickstart file, it will be replaced by RID')
|
|
||||||
optparser.add_option("", "--record-pkgs", type="string",
|
|
||||||
dest="record_pkgs", default=None,
|
|
||||||
help='Record the info of installed packages, '
|
|
||||||
'multiple values can be specified which '
|
|
||||||
'joined by ",", valid values: "name", '
|
|
||||||
'"content", "license", "vcs"')
|
|
||||||
optparser.add_option('', '--pkgmgr', type='string', dest='pkgmgr',
|
|
||||||
default=None,
|
|
||||||
help='Specify backend package manager')
|
|
||||||
optparser.add_option('', '--local-pkgs-path', type='string',
|
|
||||||
dest='local_pkgs_path', default=None,
|
|
||||||
help='Path for local pkgs(rpms) to be installed')
|
|
||||||
optparser.add_option('', '--runtime', type='string',
|
|
||||||
dest='runtime', default=None,
|
|
||||||
help='Specify runtime mode, avaiable: bootstrap, native')
|
|
||||||
# --taring-to is alias to --pack-to
|
|
||||||
optparser.add_option('', '--taring-to', type='string',
|
|
||||||
dest='pack_to', default=None,
|
|
||||||
help=SUPPRESS_HELP)
|
|
||||||
optparser.add_option('', '--pack-to', type='string',
|
|
||||||
dest='pack_to', default=None,
|
|
||||||
help='Pack the images together into the specified'
|
|
||||||
' achive, extension supported: .zip, .tar, '
|
|
||||||
'.tar.gz, .tar.bz2, etc. by default, .tar '
|
|
||||||
'will be used')
|
|
||||||
optparser.add_option('', '--copy-kernel', action='store_true',
|
|
||||||
dest='copy_kernel',
|
|
||||||
help='Copy kernel files from image /boot directory'
|
|
||||||
' to the image output directory.')
|
|
||||||
optparser.add_option('', '--install-pkgs', type='string', action='store',
|
|
||||||
dest='install_pkgs', default=None,
|
|
||||||
help='Specify what type of packages to be installed,'
|
|
||||||
' valid: source, debuginfo, debugsource')
|
|
||||||
optparser.add_option('', '--tmpfs', action='store_true', dest='enabletmpfs',
|
optparser.add_option('', '--tmpfs', action='store_true', dest='enabletmpfs',
|
||||||
help='Setup tmpdir as tmpfs to accelerate, experimental'
|
help='Setup tmpdir as tmpfs to accelerate, experimental'
|
||||||
' feature, use it if you have more than 4G memory')
|
' feature, use it if you have more than 4G memory')
|
||||||
optparser.add_option('', '--repourl', action='append',
|
|
||||||
dest='repourl', default=[],
|
|
||||||
help=SUPPRESS_HELP)
|
|
||||||
return optparser
|
return optparser
|
||||||
|
|
||||||
def preoptparse(self, argv):
|
def preoptparse(self, argv):
|
||||||
@@ -183,78 +136,16 @@ class Creator(cmdln.Cmdln):
|
|||||||
|
|
||||||
if self.options.outdir is not None:
|
if self.options.outdir is not None:
|
||||||
configmgr.create['outdir'] = abspath(self.options.outdir)
|
configmgr.create['outdir'] = abspath(self.options.outdir)
|
||||||
if self.options.cachedir is not None:
|
|
||||||
configmgr.create['cachedir'] = abspath(self.options.cachedir)
|
|
||||||
os.environ['ZYPP_LOCKFILE_ROOT'] = configmgr.create['cachedir']
|
|
||||||
|
|
||||||
for cdir in ('outdir', 'cachedir'):
|
cdir = 'outdir'
|
||||||
if os.path.exists(configmgr.create[cdir]) \
|
if os.path.exists(configmgr.create[cdir]) \
|
||||||
and not os.path.isdir(configmgr.create[cdir]):
|
and not os.path.isdir(configmgr.create[cdir]):
|
||||||
msger.error('Invalid directory specified: %s' \
|
msger.error('Invalid directory specified: %s' \
|
||||||
% configmgr.create[cdir])
|
% configmgr.create[cdir])
|
||||||
|
|
||||||
if self.options.local_pkgs_path is not None:
|
|
||||||
if not os.path.exists(self.options.local_pkgs_path):
|
|
||||||
msger.error('Local pkgs directory: \'%s\' not exist' \
|
|
||||||
% self.options.local_pkgs_path)
|
|
||||||
configmgr.create['local_pkgs_path'] = self.options.local_pkgs_path
|
|
||||||
|
|
||||||
if self.options.release:
|
|
||||||
configmgr.create['release'] = self.options.release.rstrip('/')
|
|
||||||
|
|
||||||
if self.options.record_pkgs:
|
|
||||||
configmgr.create['record_pkgs'] = []
|
|
||||||
for infotype in self.options.record_pkgs.split(','):
|
|
||||||
if infotype not in ('name', 'content', 'license', 'vcs'):
|
|
||||||
raise errors.Usage('Invalid pkg recording: %s, valid ones:'
|
|
||||||
' "name", "content", "license", "vcs"' \
|
|
||||||
% infotype)
|
|
||||||
|
|
||||||
configmgr.create['record_pkgs'].append(infotype)
|
|
||||||
|
|
||||||
if self.options.arch is not None:
|
|
||||||
supported_arch = sorted(rpmmisc.archPolicies.keys(), reverse=True)
|
|
||||||
if self.options.arch in supported_arch:
|
|
||||||
configmgr.create['arch'] = self.options.arch
|
|
||||||
else:
|
|
||||||
raise errors.Usage('Invalid architecture: "%s".\n'
|
|
||||||
' Supported architectures are: \n'
|
|
||||||
' %s' % (self.options.arch,
|
|
||||||
', '.join(supported_arch)))
|
|
||||||
|
|
||||||
if self.options.pkgmgr is not None:
|
|
||||||
configmgr.create['pkgmgr'] = self.options.pkgmgr
|
|
||||||
|
|
||||||
if self.options.runtime:
|
|
||||||
configmgr.set_runtime(self.options.runtime)
|
|
||||||
|
|
||||||
if self.options.pack_to is not None:
|
|
||||||
configmgr.create['pack_to'] = self.options.pack_to
|
|
||||||
|
|
||||||
if self.options.copy_kernel:
|
|
||||||
configmgr.create['copy_kernel'] = self.options.copy_kernel
|
|
||||||
|
|
||||||
if self.options.install_pkgs:
|
|
||||||
configmgr.create['install_pkgs'] = []
|
|
||||||
for pkgtype in self.options.install_pkgs.split(','):
|
|
||||||
if pkgtype not in ('source', 'debuginfo', 'debugsource'):
|
|
||||||
raise errors.Usage('Invalid parameter specified: "%s", '
|
|
||||||
'valid values: source, debuginfo, '
|
|
||||||
'debusource' % pkgtype)
|
|
||||||
|
|
||||||
configmgr.create['install_pkgs'].append(pkgtype)
|
|
||||||
|
|
||||||
if self.options.enabletmpfs:
|
if self.options.enabletmpfs:
|
||||||
configmgr.create['enabletmpfs'] = self.options.enabletmpfs
|
configmgr.create['enabletmpfs'] = self.options.enabletmpfs
|
||||||
|
|
||||||
if self.options.repourl:
|
|
||||||
for item in self.options.repourl:
|
|
||||||
try:
|
|
||||||
key, val = item.split('=')
|
|
||||||
except:
|
|
||||||
continue
|
|
||||||
configmgr.create['repourl'][key] = val
|
|
||||||
|
|
||||||
def main(self, argv=None):
|
def main(self, argv=None):
|
||||||
if argv is None:
|
if argv is None:
|
||||||
argv = sys.argv
|
argv = sys.argv
|
||||||
@@ -294,58 +185,3 @@ class Creator(cmdln.Cmdln):
|
|||||||
return ['help', argv[0]]
|
return ['help', argv[0]]
|
||||||
|
|
||||||
return argv
|
return argv
|
||||||
|
|
||||||
def do_auto(self, subcmd, opts, *args):
|
|
||||||
"""${cmd_name}: auto detect image type from magic header
|
|
||||||
|
|
||||||
Usage:
|
|
||||||
${name} ${cmd_name} <ksfile>
|
|
||||||
|
|
||||||
${cmd_option_list}
|
|
||||||
"""
|
|
||||||
def parse_magic_line(re_str, pstr, ptype='mic'):
|
|
||||||
ptn = re.compile(re_str)
|
|
||||||
m = ptn.match(pstr)
|
|
||||||
if not m or not m.groups():
|
|
||||||
return None
|
|
||||||
|
|
||||||
inline_argv = m.group(1).strip()
|
|
||||||
if ptype == 'mic':
|
|
||||||
m2 = re.search('(?P<format>\w+)', inline_argv)
|
|
||||||
elif ptype == 'mic2':
|
|
||||||
m2 = re.search('(-f|--format(=)?)\s*(?P<format>\w+)',
|
|
||||||
inline_argv)
|
|
||||||
else:
|
|
||||||
return None
|
|
||||||
|
|
||||||
if m2:
|
|
||||||
cmdname = m2.group('format')
|
|
||||||
inline_argv = inline_argv.replace(m2.group(0), '')
|
|
||||||
return (cmdname, inline_argv)
|
|
||||||
|
|
||||||
return None
|
|
||||||
|
|
||||||
if len(args) != 1:
|
|
||||||
raise errors.Usage("Extra arguments given")
|
|
||||||
|
|
||||||
if not os.path.exists(args[0]):
|
|
||||||
raise errors.CreatorError("Can't find the file: %s" % args[0])
|
|
||||||
|
|
||||||
with open(args[0], 'r') as rf:
|
|
||||||
first_line = rf.readline()
|
|
||||||
|
|
||||||
mic_re = '^#\s*-\*-mic-options-\*-\s+(.*)\s+-\*-mic-options-\*-'
|
|
||||||
mic2_re = '^#\s*-\*-mic2-options-\*-\s+(.*)\s+-\*-mic2-options-\*-'
|
|
||||||
|
|
||||||
result = parse_magic_line(mic_re, first_line, 'mic') \
|
|
||||||
or parse_magic_line(mic2_re, first_line, 'mic2')
|
|
||||||
if not result:
|
|
||||||
raise errors.KsError("Invalid magic line in file: %s" % args[0])
|
|
||||||
|
|
||||||
if result[0] not in self._subcmds:
|
|
||||||
raise errors.KsError("Unsupport format '%s' in %s"
|
|
||||||
% (result[0], args[0]))
|
|
||||||
|
|
||||||
argv = ' '.join(result + args).split()
|
|
||||||
self.main(argv)
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user