1eb8dc403SDave Cobbley# Development tool - package command plugin
2eb8dc403SDave Cobbley#
3eb8dc403SDave Cobbley# Copyright (C) 2014-2015 Intel Corporation
4eb8dc403SDave Cobbley#
5*c342db35SBrad Bishop# SPDX-License-Identifier: GPL-2.0-only
6eb8dc403SDave Cobbley#
7eb8dc403SDave Cobbley"""Devtool plugin containing the package subcommands"""
8eb8dc403SDave Cobbley
9eb8dc403SDave Cobbleyimport os
10eb8dc403SDave Cobbleyimport subprocess
11eb8dc403SDave Cobbleyimport logging
12eb8dc403SDave Cobbleyfrom bb.process import ExecutionError
13eb8dc403SDave Cobbleyfrom devtool import exec_build_env_command, setup_tinfoil, check_workspace_recipe, DevtoolError
14eb8dc403SDave Cobbley
15eb8dc403SDave Cobbleylogger = logging.getLogger('devtool')
16eb8dc403SDave Cobbley
17eb8dc403SDave Cobbleydef package(args, config, basepath, workspace):
18eb8dc403SDave Cobbley    """Entry point for the devtool 'package' subcommand"""
19eb8dc403SDave Cobbley    check_workspace_recipe(workspace, args.recipename)
20eb8dc403SDave Cobbley
21eb8dc403SDave Cobbley    tinfoil = setup_tinfoil(basepath=basepath, config_only=True)
22eb8dc403SDave Cobbley    try:
23eb8dc403SDave Cobbley        image_pkgtype = config.get('Package', 'image_pkgtype', '')
24eb8dc403SDave Cobbley        if not image_pkgtype:
25eb8dc403SDave Cobbley            image_pkgtype = tinfoil.config_data.getVar('IMAGE_PKGTYPE')
26eb8dc403SDave Cobbley
27eb8dc403SDave Cobbley        deploy_dir_pkg = tinfoil.config_data.getVar('DEPLOY_DIR_%s' % image_pkgtype.upper())
28eb8dc403SDave Cobbley    finally:
29eb8dc403SDave Cobbley        tinfoil.shutdown()
30eb8dc403SDave Cobbley
31eb8dc403SDave Cobbley    package_task = config.get('Package', 'package_task', 'package_write_%s' % image_pkgtype)
32eb8dc403SDave Cobbley    try:
33eb8dc403SDave Cobbley        exec_build_env_command(config.init_path, basepath, 'bitbake -c %s %s' % (package_task, args.recipename), watch=True)
34eb8dc403SDave Cobbley    except bb.process.ExecutionError as e:
35eb8dc403SDave Cobbley        # We've already seen the output since watch=True, so just ensure we return something to the user
36eb8dc403SDave Cobbley        return e.exitcode
37eb8dc403SDave Cobbley
38eb8dc403SDave Cobbley    logger.info('Your packages are in %s' % deploy_dir_pkg)
39eb8dc403SDave Cobbley
40eb8dc403SDave Cobbley    return 0
41eb8dc403SDave Cobbley
42eb8dc403SDave Cobbleydef register_commands(subparsers, context):
43eb8dc403SDave Cobbley    """Register devtool subcommands from the package plugin"""
44eb8dc403SDave Cobbley    if context.fixed_setup:
45eb8dc403SDave Cobbley        parser_package = subparsers.add_parser('package',
46eb8dc403SDave Cobbley                                               help='Build packages for a recipe',
47eb8dc403SDave Cobbley                                               description='Builds packages for a recipe\'s output files',
48eb8dc403SDave Cobbley                                               group='testbuild', order=-5)
49eb8dc403SDave Cobbley        parser_package.add_argument('recipename', help='Recipe to package')
50eb8dc403SDave Cobbley        parser_package.set_defaults(func=package)
51