2016-05-12 07:30:35 +00:00
|
|
|
#!/usr/bin/env python3
|
2011-02-07 17:50:27 +00:00
|
|
|
|
2011-03-02 17:59:38 +00:00
|
|
|
# This script has subcommands which operate against your bitbake layers, either
|
|
|
|
# displaying useful information, or acting against them.
|
2011-08-12 10:40:18 +00:00
|
|
|
# See the help output for details on available commands.
|
2011-03-02 17:59:38 +00:00
|
|
|
|
2012-01-30 16:25:49 +00:00
|
|
|
# Copyright (C) 2011 Mentor Graphics Corporation
|
2015-02-20 17:52:41 +00:00
|
|
|
# Copyright (C) 2011-2015 Intel Corporation
|
2012-08-27 20:44:31 +00:00
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License version 2 as
|
|
|
|
# published by the Free Software Foundation.
|
|
|
|
#
|
|
|
|
# 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.,
|
|
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
2012-01-30 16:25:49 +00:00
|
|
|
|
2011-02-07 17:50:27 +00:00
|
|
|
import logging
|
2011-07-25 18:29:53 +00:00
|
|
|
import os
|
2011-02-07 17:50:27 +00:00
|
|
|
import sys
|
2015-02-20 17:52:41 +00:00
|
|
|
import argparse
|
2011-02-07 17:50:27 +00:00
|
|
|
|
|
|
|
bindir = os.path.dirname(__file__)
|
|
|
|
topdir = os.path.dirname(bindir)
|
|
|
|
sys.path[0:0] = [os.path.join(topdir, 'lib')]
|
|
|
|
|
2012-08-27 20:44:31 +00:00
|
|
|
import bb.tinfoil
|
2017-03-27 00:17:27 +00:00
|
|
|
import bb.msg
|
2011-02-07 17:50:27 +00:00
|
|
|
|
2017-03-27 00:17:27 +00:00
|
|
|
logger = bb.msg.logger_create('bitbake-layers', sys.stdout)
|
2011-02-07 17:50:27 +00:00
|
|
|
|
2015-02-20 17:52:41 +00:00
|
|
|
def main():
|
2016-04-30 19:41:00 +00:00
|
|
|
parser = argparse.ArgumentParser(
|
|
|
|
description="BitBake layers utility",
|
|
|
|
epilog="Use %(prog)s <subcommand> --help to get help on a specific command",
|
|
|
|
add_help=False)
|
2015-02-20 17:52:41 +00:00
|
|
|
parser.add_argument('-d', '--debug', help='Enable debug output', action='store_true')
|
|
|
|
parser.add_argument('-q', '--quiet', help='Print only errors', action='store_true')
|
2016-04-30 19:41:00 +00:00
|
|
|
parser.add_argument('--color', choices=['auto', 'always', 'never'], default='auto', help='Colorize output (where %(metavar)s is %(choices)s)', metavar='COLOR')
|
2015-02-20 17:52:41 +00:00
|
|
|
|
2016-04-30 19:41:00 +00:00
|
|
|
global_args, unparsed_args = parser.parse_known_args()
|
2015-02-20 17:52:41 +00:00
|
|
|
|
2016-04-30 19:41:00 +00:00
|
|
|
# Help is added here rather than via add_help=True, as we don't want it to
|
|
|
|
# be handled by parse_known_args()
|
|
|
|
parser.add_argument('-h', '--help', action='help', default=argparse.SUPPRESS,
|
|
|
|
help='show this help message and exit')
|
|
|
|
subparsers = parser.add_subparsers(title='subcommands', metavar='<subcommand>')
|
2016-05-12 07:30:35 +00:00
|
|
|
subparsers.required = True
|
2015-02-20 17:52:41 +00:00
|
|
|
|
2016-04-30 19:41:00 +00:00
|
|
|
if global_args.debug:
|
|
|
|
logger.setLevel(logging.DEBUG)
|
|
|
|
elif global_args.quiet:
|
|
|
|
logger.setLevel(logging.ERROR)
|
2015-02-20 17:52:41 +00:00
|
|
|
|
2017-03-27 00:17:27 +00:00
|
|
|
# Need to re-run logger_create with color argument
|
|
|
|
# (will be the same logger since it has the same name)
|
|
|
|
bb.msg.logger_create('bitbake-layers', output=sys.stdout, color=global_args.color)
|
2015-02-20 17:52:41 +00:00
|
|
|
|
2016-04-30 19:41:00 +00:00
|
|
|
plugins = []
|
bitbake: bitbake-layers: Handle exception raised bytinfoil.prepare()
The tinfoil.prepare method can raise Exceptions when is parsing initial
data so add this call inside try, finally to avoid get blocked for
don't call tinfoil.shutdown().
The tinfoil_init function was remove because isn't make sense now since
tinfoil.prepare() needs to be inside try, finally closures.
Example of raised exception and gets blocked:
$ bitbake-layers add-layer ~/repos/meta-openembedded/meta-python/
Traceback (most recent call last):
File "/home/alimon/repos/poky/bitbake/bin/bitbake-layers", line 83, in
main
tinfoil.prepare(True)
...
File "/home/alimon/repos/poky/bitbake/lib/bb/tinfoil.py", line 268, in
run_command
raise TinfoilCommandFailed(result[1])
bb.tinfoil.TinfoilCommandFailed: Traceback (most recent call last):
File "/home/alimon/repos/poky/bitbake/lib/bb/command.py", line 81, in
runCommand
result = command_method(self, commandline)
...
File "/home/alimon/repos/poky/bitbake/lib/bb/cooker.py", line 1314, in
handleCollections
raise CollectionError("Errors during parsing layer configuration")
bb.cooker.CollectionError: Errors during parsing layer configuration
(Bitbake rev: 61ebe9a026652e32f9482f66fc3fe7a8672fc093)
Signed-off-by: Aníbal Limón <anibal.limon@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2017-02-02 22:29:21 +00:00
|
|
|
tinfoil = bb.tinfoil.Tinfoil(tracking=True)
|
|
|
|
tinfoil.logger.setLevel(logger.getEffectiveLevel())
|
2015-08-05 14:47:12 +00:00
|
|
|
try:
|
bitbake: bitbake-layers: Handle exception raised bytinfoil.prepare()
The tinfoil.prepare method can raise Exceptions when is parsing initial
data so add this call inside try, finally to avoid get blocked for
don't call tinfoil.shutdown().
The tinfoil_init function was remove because isn't make sense now since
tinfoil.prepare() needs to be inside try, finally closures.
Example of raised exception and gets blocked:
$ bitbake-layers add-layer ~/repos/meta-openembedded/meta-python/
Traceback (most recent call last):
File "/home/alimon/repos/poky/bitbake/bin/bitbake-layers", line 83, in
main
tinfoil.prepare(True)
...
File "/home/alimon/repos/poky/bitbake/lib/bb/tinfoil.py", line 268, in
run_command
raise TinfoilCommandFailed(result[1])
bb.tinfoil.TinfoilCommandFailed: Traceback (most recent call last):
File "/home/alimon/repos/poky/bitbake/lib/bb/command.py", line 81, in
runCommand
result = command_method(self, commandline)
...
File "/home/alimon/repos/poky/bitbake/lib/bb/cooker.py", line 1314, in
handleCollections
raise CollectionError("Errors during parsing layer configuration")
bb.cooker.CollectionError: Errors during parsing layer configuration
(Bitbake rev: 61ebe9a026652e32f9482f66fc3fe7a8672fc093)
Signed-off-by: Aníbal Limón <anibal.limon@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2017-02-02 22:29:21 +00:00
|
|
|
tinfoil.prepare(True)
|
2015-08-05 14:47:12 +00:00
|
|
|
for path in ([topdir] +
|
2016-11-25 15:28:08 +00:00
|
|
|
tinfoil.config_data.getVar('BBPATH').split(':')):
|
2015-08-05 14:47:12 +00:00
|
|
|
pluginpath = os.path.join(path, 'lib', 'bblayers')
|
|
|
|
bb.utils.load_plugins(logger, plugins, pluginpath)
|
|
|
|
|
|
|
|
registered = False
|
|
|
|
for plugin in plugins:
|
|
|
|
if hasattr(plugin, 'register_commands'):
|
|
|
|
registered = True
|
|
|
|
plugin.register_commands(subparsers)
|
|
|
|
if hasattr(plugin, 'tinfoil_init'):
|
|
|
|
plugin.tinfoil_init(tinfoil)
|
|
|
|
|
|
|
|
if not registered:
|
|
|
|
logger.error("No commands registered - missing plugins?")
|
|
|
|
sys.exit(1)
|
|
|
|
|
|
|
|
args = parser.parse_args(unparsed_args, namespace=global_args)
|
|
|
|
|
|
|
|
if getattr(args, 'parserecipes', False):
|
|
|
|
tinfoil.config_data.disableTracking()
|
|
|
|
tinfoil.parseRecipes()
|
|
|
|
tinfoil.config_data.enableTracking()
|
|
|
|
|
|
|
|
return args.func(args)
|
|
|
|
finally:
|
|
|
|
tinfoil.shutdown()
|
2015-02-20 17:52:41 +00:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
try:
|
|
|
|
ret = main()
|
2016-04-30 19:41:00 +00:00
|
|
|
except bb.BBHandledException:
|
|
|
|
ret = 1
|
2015-02-20 17:52:41 +00:00
|
|
|
except Exception:
|
|
|
|
ret = 1
|
|
|
|
import traceback
|
2016-03-31 11:47:13 +00:00
|
|
|
traceback.print_exc()
|
2015-02-20 17:52:41 +00:00
|
|
|
sys.exit(ret)
|