Files
poky/bitbake/bin/bitbake-getvar
Paulo Neves f98bf56074 bitbake: bitbake-getvar: Add a quiet command line argument
bitbake-getvar does not have a way to silence bitbake
server's logger and that makes the tool hard to use for
text processing. This is especially true when one wants to
get a bitbake value to be piped to some other utility and
instead we get uncontrolled logging messages or warnings
together with bitbake's variable value.

Example without quiet:
bitbake-getvar --value MACHINE
NOTE: Starting bitbake server...
qemux86-64

With quiet:
bitbake-getvar --value MACHINE --quiet
qemux86-64

(Bitbake rev: af354e975d0b4c26d0e91e3c82946b093bc11b45)

Signed-off-by: Paulo Neves <ptsneves@gmail.com>
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
2023-01-26 21:50:31 +00:00

1.9 KiB
Executable File

#! /usr/bin/env python3

Copyright (C) 2021 Richard Purdie

SPDX-License-Identifier: GPL-2.0-only

import argparse import io import os import sys import warnings warnings.simplefilter("default")

bindir = os.path.dirname(file) topdir = os.path.dirname(bindir) sys.path[0:0] = [os.path.join(topdir, 'lib')]

import bb.tinfoil

if name == "main": parser = argparse.ArgumentParser(description="Bitbake Query Variable") parser.add_argument("variable", help="variable name to query") parser.add_argument("-r", "--recipe", help="Recipe name to query", default=None, required=False) parser.add_argument('-u', '--unexpand', help='Do not expand the value (with --value)', action="store_true") parser.add_argument('-f', '--flag', help='Specify a variable flag to query (with --value)', default=None) parser.add_argument('--value', help='Only report the value, no history and no variable name', action="store_true") parser.add_argument('-q', '--quiet', help='Silence bitbake server logging', action="store_true") args = parser.parse_args()

if args.unexpand and not args.value:
    print("--unexpand only makes sense with --value")
    sys.exit(1)

if args.flag and not args.value:
    print("--flag only makes sense with --value")
    sys.exit(1)

with bb.tinfoil.Tinfoil(tracking=True, setup_logging=not args.quiet) as tinfoil:
    if args.recipe:
        tinfoil.prepare(quiet=2)
        d = tinfoil.parse_recipe(args.recipe)
    else:
        tinfoil.prepare(quiet=2, config_only=True)
        d = tinfoil.config_data
    if args.flag:
        print(str(d.getVarFlag(args.variable, args.flag, expand=(not args.unexpand))))
    elif args.value:
        print(str(d.getVar(args.variable, expand=(not args.unexpand))))
    else:
        bb.data.emit_var(args.variable, d=d, all=True)