You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
47 lines
1.7 KiB
47 lines
1.7 KiB
# Copyright (c) 2018 Foundries.io |
|
# |
|
# SPDX-License-Identifier: Apache-2.0 |
|
|
|
'''Helpers shared by multiple west extension command modules. |
|
|
|
Note that common helpers used by the flash and debug extension |
|
commands are in run_common -- that's for common code used by |
|
commands which specifically execute runners.''' |
|
|
|
import os |
|
from pathlib import Path |
|
|
|
from west import log |
|
from west.commands import WestCommand |
|
|
|
# This relies on this file being zephyr/scripts/foo/bar.py. |
|
# If you move this file, you'll break it, so be careful. |
|
THIS_ZEPHYR = Path(__file__).parent.parent.parent |
|
ZEPHYR_BASE = Path(os.environ.get('ZEPHYR_BASE', THIS_ZEPHYR)) |
|
|
|
# FIXME we need a nicer way to handle imports from scripts and cmake than this. |
|
ZEPHYR_SCRIPTS = ZEPHYR_BASE / 'scripts' |
|
ZEPHYR_CMAKE = ZEPHYR_BASE / 'cmake' |
|
|
|
class Forceable(WestCommand): |
|
'''WestCommand subclass for commands with a --force option.''' |
|
|
|
@staticmethod |
|
def add_force_arg(parser): |
|
'''Add a -f / --force option to the parser.''' |
|
parser.add_argument('-f', '--force', action='store_true', |
|
help='ignore any errors and try to proceed') |
|
|
|
def check_force(self, cond, msg): |
|
'''Abort if the command needs to be forced and hasn't been. |
|
|
|
The "forced" predicate must be in self.args.forced. |
|
|
|
If cond and self.args.force are both False, scream and die |
|
with message msg. Otherwise, return. That is, "cond" is a |
|
condition which means everything is OK; if it's False, only |
|
self.args.force being True can allow execution to proceed. |
|
''' |
|
if not (cond or self.args.force): |
|
log.err(msg) |
|
log.die('refusing to proceed without --force due to above error')
|
|
|