wic: flatten imager class hierarchy

wic code is hard to follow due to deep and twiggy class
inheritance tree.

Flatten imager tree:
 wic -> wic_create -> Creator -> DirectPlugin -> DirectImageCreator
to
 wic -> wic_create -> DirectPlugin
by
 removing Creator class and creator module
 merging DirectImageCreator into DirectPlugin

Changed APIs to use the same parameters names.

Passed parsed command line options as an object down the stack.

(From OE-Core rev: 1e28d512341ce470c7afb256a01e597ab87170ca)

Signed-off-by: Ed Bartosh <ed.bartosh@linux.intel.com>
Signed-off-by: Ross Burton <ross.burton@intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
Ed Bartosh 2017-02-03 22:26:06 +02:00 committed by Richard Purdie
parent 3e052dd58c
commit 71ce8d09e0
4 changed files with 56 additions and 193 deletions

View File

@ -1,106 +0,0 @@
#!/usr/bin/env python -tt
#
# Copyright (c) 2011 Intel, Inc.
#
# This program is free software; you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by the Free
# Software Foundation; version 2 of the License
#
# This program is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
# for more details.
#
# You should have received a copy of the GNU General Public License along
# with this program; if not, write to the Free Software Foundation, Inc., 59
# Temple Place - Suite 330, Boston, MA 02111-1307, USA.
import os, sys
from optparse import OptionParser, SUPPRESS_HELP
from wic import msger
from wic.utils import errors
from wic.plugin import pluginmgr
class Creator():
"""${name}: create an image
Usage:
${name} SUBCOMMAND <ksfile> [OPTS]
${command_list}
${option_list}
"""
name = 'wic create(cr)'
def __init__(self, *args, **kwargs):
self._subcmds = {}
# get cmds from pluginmgr
# mix-in do_subcmd interface
for subcmd, klass in pluginmgr.get_plugins('imager').items():
if not hasattr(klass, 'do_create'):
msger.warning("Unsupported subcmd: %s" % subcmd)
continue
func = getattr(klass, 'do_create')
self._subcmds[subcmd] = func
def get_optparser(self):
optparser = OptionParser()
optparser.add_option('-d', '--debug', action='store_true',
dest='debug',
help=SUPPRESS_HELP)
optparser.add_option('-v', '--verbose', action='store_true',
dest='verbose',
help=SUPPRESS_HELP)
optparser.add_option('', '--logfile', type='string', dest='logfile',
default=None,
help='Path of logfile')
optparser.add_option('-c', '--config', type='string', dest='config',
default=None,
help='Specify config file for wic')
optparser.add_option('-o', '--outdir', type='string', action='store',
dest='outdir', default=None,
help='Output directory')
optparser.add_option('', '--tmpfs', action='store_true', dest='enabletmpfs',
help='Setup tmpdir as tmpfs to accelerate, experimental'
' feature, use it if you have more than 4G memory')
optparser.add_option('', '--bmap', action='store_true', help='generate .bmap')
return optparser
def postoptparse(self, options):
abspath = lambda pth: os.path.abspath(os.path.expanduser(pth))
if options.verbose:
msger.set_loglevel('verbose')
if options.debug:
msger.set_loglevel('debug')
if options.logfile:
logfile_abs_path = abspath(options.logfile)
if os.path.isdir(logfile_abs_path):
raise errors.Usage("logfile's path %s should be file"
% options.logfile)
if not os.path.exists(os.path.dirname(logfile_abs_path)):
os.makedirs(os.path.dirname(logfile_abs_path))
msger.set_interactive(False)
msger.set_logfile(logfile_abs_path)
def main(self, argv=None):
if argv is None:
argv = sys.argv
else:
argv = argv[:] # don't modify caller's list
pname = argv[0]
if pname not in self._subcmds:
msger.error('Unknown plugin: %s' % pname)
optparser = self.get_optparser()
options, args = optparser.parse_args(argv)
self.postoptparse(options)
return self._subcmds[pname](options, *args[1:])

View File

@ -31,7 +31,7 @@
import os import os
import sys import sys
from wic import msger, creator from wic import msger
from wic.plugin import pluginmgr from wic.plugin import pluginmgr
from wic.utils.misc import get_bitbake_var from wic.utils.misc import get_bitbake_var
@ -145,10 +145,10 @@ def list_source_plugins():
print(" %s" % plugin) print(" %s" % plugin)
def wic_create(wks_file, rootfs_dir, bootimg_dir, kernel_dir, def wic_create(wks_file, rootfs_dir, bootimg_dir, kernel_dir, native_sysroot,
native_sysroot, scripts_path, image_output_dir, scripts_path, options):
compressor, bmap, debug): """
"""Create image Create image
wks_file - user-defined OE kickstart file wks_file - user-defined OE kickstart file
rootfs_dir - absolute path to the build's /rootfs dir rootfs_dir - absolute path to the build's /rootfs dir
@ -157,8 +157,7 @@ def wic_create(wks_file, rootfs_dir, bootimg_dir, kernel_dir,
native_sysroot - absolute path to the build's native sysroots dir native_sysroot - absolute path to the build's native sysroots dir
scripts_path - absolute path to /scripts dir scripts_path - absolute path to /scripts dir
image_output_dir - dirname to create for image image_output_dir - dirname to create for image
compressor - compressor utility to compress the image options - wic command line options (debug, bmap, etc)
bmap - enable generation of .bmap
Normally, the values for the build artifacts values are determined Normally, the values for the build artifacts values are determined
by 'wic -e' from the output of the 'bitbake -e' command given an by 'wic -e' from the output of the 'bitbake -e' command given an
@ -184,20 +183,21 @@ def wic_create(wks_file, rootfs_dir, bootimg_dir, kernel_dir,
print("BUILDDIR not found, exiting. (Did you forget to source oe-init-build-env?)") print("BUILDDIR not found, exiting. (Did you forget to source oe-init-build-env?)")
sys.exit(1) sys.exit(1)
if debug: if options.debug:
msger.set_loglevel('debug') msger.set_loglevel('debug')
if not os.path.exists(image_output_dir): if not os.path.exists(options.outdir):
os.makedirs(image_output_dir) os.makedirs(options.outdir)
crobj = creator.Creator() pname = 'direct'
plugin_class = pluginmgr.get_plugins('imager').get(pname)
if not plugin_class:
msger.error('Unknown plugin: %s' % pname)
cmdline = ["direct", native_sysroot, kernel_dir, bootimg_dir, rootfs_dir, plugin = plugin_class(wks_file, rootfs_dir, bootimg_dir, kernel_dir,
wks_file, image_output_dir, oe_builddir, compressor or ""] native_sysroot, scripts_path, oe_builddir, options)
if bmap:
cmdline.append('--bmap')
crobj.main(cmdline) plugin.do_create()
print("\nThe image(s) were created using OE kickstart file:\n %s" % wks_file) print("\nThe image(s) were created using OE kickstart file:\n %s" % wks_file)

View File

@ -39,50 +39,6 @@ from wic.utils.errors import CreatorError, ImageError
from wic.utils.misc import get_bitbake_var, exec_cmd, exec_native_cmd from wic.utils.misc import get_bitbake_var, exec_cmd, exec_native_cmd
from wic.utils.partitionedfs import Image from wic.utils.partitionedfs import Image
class DirectPlugin(ImagerPlugin):
"""
Install a system into a file containing a partitioned disk image.
An image file is formatted with a partition table, each partition
created from a rootfs or other OpenEmbedded build artifact and dd'ed
into the virtual disk. The disk image can subsequently be dd'ed onto
media and used on actual hardware.
"""
name = 'direct'
@staticmethod
def do_create(opts, *args):
"""
Create direct image, called from creator as 'direct' cmd
"""
native_sysroot, kernel_dir, bootimg_dir, rootfs_dir, ksconf, \
outdir, oe_builddir, compressor = args
try:
ksobj = KickStart(ksconf)
except KickStartError as err:
msger.error(str(err))
name = "%s-%s" % (os.path.splitext(os.path.basename(ksconf))[0],
strftime("%Y%m%d%H%M"))
# parse possible 'rootfs=name' items
krootfs_dir = dict(rdir.split('=') for rdir in rootfs_dir.split(' '))
creator = DirectImageCreator(name, ksobj, oe_builddir, outdir,
krootfs_dir, bootimg_dir, kernel_dir,
native_sysroot, compressor, opts.bmap)
try:
creator.create()
creator.assemble()
creator.finalize()
creator.print_info()
except errors.CreatorError:
raise
finally:
creator.cleanup()
class DiskImage(): class DiskImage():
""" """
A Disk backed by a file. A Disk backed by a file.
@ -101,43 +57,57 @@ class DiskImage():
self.created = True self.created = True
class DirectImageCreator: class DirectPlugin(ImagerPlugin):
""" """
Installs a system into a file containing a partitioned disk image. Install a system into a file containing a partitioned disk image.
DirectImageCreator is an advanced ImageCreator subclass; an image An image file is formatted with a partition table, each partition
file is formatted with a partition table, each partition created created from a rootfs or other OpenEmbedded build artifact and dd'ed
from a rootfs or other OpenEmbedded build artifact and dd'ed into into the virtual disk. The disk image can subsequently be dd'ed onto
the virtual disk. The disk image can subsequently be dd'ed onto
media and used on actual hardware. media and used on actual hardware.
""" """
name = 'direct'
def __init__(self, name, ksobj, oe_builddir, outdir, def __init__(self, wks_file, rootfs_dir, bootimg_dir, kernel_dir,
rootfs_dir, bootimg_dir, kernel_dir, native_sysroot, scripts_path, oe_builddir, options):
native_sysroot, compressor, bmap=False): try:
""" self.ks = KickStart(wks_file)
Initialize a DirectImageCreator instance. except KickStartError as err:
msger.error(str(err))
This method takes the same arguments as ImageCreator.__init__() # parse possible 'rootfs=name' items
""" self.rootfs_dir = dict(rdir.split('=') for rdir in rootfs_dir.split(' '))
self.name = name self.bootimg_dir = bootimg_dir
self.outdir = outdir self.kernel_dir = kernel_dir
self.workdir = tempfile.mkdtemp(dir=outdir, prefix='tmp.wic.') self.native_sysroot = native_sysroot
self.ks = ksobj self.oe_builddir = oe_builddir
self.outdir = options.outdir
self.compressor = options.compressor
self.bmap = options.bmap
self.name = "%s-%s" % (os.path.splitext(os.path.basename(wks_file))[0],
strftime("%Y%m%d%H%M"))
self.workdir = tempfile.mkdtemp(dir=self.outdir, prefix='tmp.wic.')
self._image = None self._image = None
self._disks = {} self._disks = {}
self._disk_format = "direct" self._disk_format = "direct"
self._disk_names = [] self._disk_names = []
self.ptable_format = self.ks.bootloader.ptable self.ptable_format = self.ks.bootloader.ptable
self.oe_builddir = oe_builddir def do_create(self):
self.rootfs_dir = rootfs_dir """
self.bootimg_dir = bootimg_dir Plugin entry point.
self.kernel_dir = kernel_dir """
self.native_sysroot = native_sysroot try:
self.compressor = compressor self.create()
self.bmap = bmap self.assemble()
self.finalize()
self.print_info()
except errors.CreatorError:
raise
finally:
self.cleanup()
def _get_part_num(self, num, parts): def _get_part_num(self, num, parts):
"""calculate the real partition number, accounting for partitions not """calculate the real partition number, accounting for partitions not
@ -359,7 +329,7 @@ class DirectImageCreator:
extension = "direct" + {"gzip": ".gz", extension = "direct" + {"gzip": ".gz",
"bzip2": ".bz2", "bzip2": ".bz2",
"xz": ".xz", "xz": ".xz",
"": ""}.get(self.compressor) None: ""}.get(self.compressor)
full_path = self._full_path(self.outdir, disk_name, extension) full_path = self._full_path(self.outdir, disk_name, extension)
msg += ' %s\n\n' % full_path msg += ' %s\n\n' % full_path

View File

@ -250,8 +250,7 @@ def wic_create_subcommand(args, usage_str):
print("Creating image(s)...\n") print("Creating image(s)...\n")
engine.wic_create(wks_file, rootfs_dir, bootimg_dir, kernel_dir, engine.wic_create(wks_file, rootfs_dir, bootimg_dir, kernel_dir,
native_sysroot, scripts_path, options.outdir, native_sysroot, scripts_path, options)
options.compressor, options.bmap, options.debug)
def wic_list_subcommand(args, usage_str): def wic_list_subcommand(args, usage_str):